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BASIC OPERATING PROCEDURE 


The following instructions are basic operating procedures for loading 
and running the disc diagnostic from paper tape. Refer to the 
Diagnostic Configurator Reference Manual, part no. 02100-90157, for 
loading the disc diagnostic from any other media. 

Note* When running the diagnostic, use a scratch cartridge/pack if 
data on the current cartridge/pack is to be saved since all 
information on the cartridge/pack used may be replaced. Refer 
to the TS and CP instruction in the OPDSN portion of this 
manual for saving/restoring data on a fixed surface. 

Note: On a 7905/7906 Drive, set the LOWER DISC PROTECT switch if 

data on the fixed disc is to be saved. 

a. Load the Diagnostic Configurator into memory as follows* 

(1) For a 2100A/S, load a starting address of X7700 (octal) into 
the P-register, where* 

X = 3 for 16K words of memory 

X = 5 for 24K words of memory 

X = 7 for 32K or more words of memory 

(2) For a 21MX M-Series or 21MX E-Series, set bits 11-6 of Switch 
Register (clear Switch Register if 2 1 00 A/S is used) to the 
octal select code of the paper tape reader. 

(3) Press PRESET (INTERNAL and EXTERNAL). 

(4) Press IBL (LDR ENABLE). 

(5) Press RUN. The computer should halt with 102077 (octal) 
displayed in the Display Register, indicating a successful 
load. Refer to the Diagnostic Configurator Reference Manual 
for any other halts. 

b. Configure the Diagnostic Configurator and load the HP 79XX/13037 
Disc Memory Diagnostic into memory as follows: 

(1) Load a starting address of 100 (octal) into P-register. 

(2) Set S-register to 00XXYV (octal), where* 

XX - bits 11-6 = select code of paper tape reader 
YY » bits 5-0 = select code of console 
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(3) 


Press PRESET (INTERNAL and EXTERNAL) 


(4) Press RUN, The computer will halt with 102077 (octal) 

displayed in the Display Register indicating a successful 
configuration and load. (A HALT 102022 (octal) indicates an 
invalid console select code or the console was not ready.) 

c. Configure the diagnostic program as follows* 

(1) Load a starting address of 100 (octal) into the P-register. 

(2) Set bits 5-0 of Switch Register to octal select code of I/O 
channel containing the controller interface PCA. Set bit 14 
to select DMA channel 7, otherwise DMA channel 6 is the 
default channel. 

(3) Press PRESET (INTERNAL and EXTERNAL). 

(4) Press RUN. The computer will halt with 102074 (octal) 
displayed in tne Display Register, indicating proper select 
code entered. (A HALT 102073 (octal) indicates an invalid 
select code was entered above.) 

d. Run disc controller test (short pass), or disc media test (long 

pass) on unit 0 as follows: 

(1) Power-up drive and load heads, thus ensuring the correct 
default values for the head table are used in the diagnostic. 

(2) Load a starting address of 2000 (octal) into the P-register. 

(3) Set Switch Register to 040141 (octal) (bits 14,6,5, and 0) 
for short pass, or to 040001 (octal) (bits 14 and 0) for long 
pass . 

(4) Press PRESET (INTERNAL and EXTERNAL). 

(5) Press RUN. Introductory message HO 79XX/13037 Disc Memory 
Diagnostic is output. If execution is not a restart, message 
UNIT TABLE: 01 DRIVE (S) 0 followed by H25 WISH TO CHANGE? is 
output. Respond NO <return> if the unit table is not to be 
changed. Otherwise, respond YES <return> and change as 
desired. 

(6) After completion of a sufficient number o i passes, set bit 15 
of the Switch Register to halt the diagnostic. 

Refer to error messages listed in Appendix A of this manual if 

errors occur. Refer to section II of this manual if the step 

where the error occurred is output. 
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I SECTION I 

INTRODUCTION I I 

i I I 
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1-1. GENERAL 

This manual describes the loading and use of the HP 79XX/13037 Disc 
Memory Diagnostic (hereafter called the diagnostic). The program 
confirms proper input, output, and control functions for a disc 
subsystem which includes an HP 7905, 7906, 7920, or 7925 Disc Drive. 
The diagnostic provides rapid checkout of the controller and 
exhaustive testing of the drive. 

Tne diagnostic can be executed automatically or manually in which case 
the operator defines his own tests with console and switch register 
options . 

A maximum of eight drives can be tested sequentially and interaction 
between drives is also tested. Any combination of 7905, 7906, 7920, 
and 7925 Drives may be tested at one time. 

The diagnostic also tests the drives in a very limited manner in a 
multiple CPU environment. It does not test more than one controller 
nor more than one CPU interface at a time. Refer to paragraph 3-6 for 
further datails. 

The diagnostic is available on media which includes paper tape, 
cartridge tape, and disc. 

1-2. REQUIRED HARDWARE 

The following hardware is required: 

a. An HP 2100A/S, 21MX M-Series, or 21MX E-Series Computer (refered 
to as "2100-Series") with at least 16K-words of memory and 

DMA /DC PC « 

b. A disc subsystem consisting of an HP 7905, 7906, 7920, or 7925 
Disc Drive,- an HP 13037A/3 Disc Controller, and an HP 2100-Series 
Interface PCA. 

c. A program loading device. 

d. A console device. 

e. A line printer (optional). 

f. A punch device (required if paper tape dump routine is used). 
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1-3. REQUIRED SOFTWARE 

The following software is required: 

a. The Diagnostic Configurator, absolute binary program, part no. 
24296-60001, date coded 1627 or later. Reference Manual, part no. 
02100-90157. 

b. HP 79XX/130 37A/B Disc Memory Diagnostic, absolute binary program, 
part no. 12962-16001. 

The diagnostic serial number (DSN) for this diagnostic is 151403 
(octal) and is contained in memory location 126 (octal) . 


1-4. DIAGNOSTIC LIMITATIONS 


Unexpected interrupts form a special class of errors? no message is 
output. The interrupts are a result of an interrupt on an I/O select 
channel not being used by the diagnostic. Each interrupt trap cell 
contains 1060XX (octal), where XX is the trap location. Analysis of 
these errors is beyond the scope of this diagnostic. No recovery 
mechanism is provided. 

Interface capability for receiving, passing, and denying interrupt 
priority (priority string logic) is not usually tested by the 
diagnostic. A partial test of this is to remove an interface of a 
lower select code than that of the controller interface and run the 
diagnostic. The interface will not receive priority on an interrupt 
and error message E6 NO INTERRUPT will be output. 

Whenever the heads load on any unit while running the diagnostic, 
except in test section 1, step 15, an unexpected interrupt will occur 
(the controller channel flag on the interface is set). This interrupt 
is not expected by the diagnostic and is reported as an error. Ihe 
error message that results and the number of errors output depend on 
what the diagnostic is doing at the time of the unexpected interrupt. 

Note* Step 15 expects the heads to load, thus an error is not 
reported. 

Whenever PRESET is pushed (PRESET sends a clear command to the 
controller when jumpers are placed to allow it), the controller will 
cause an unexpected attention, except in test section 1, step 20 ! . 

The controller function "Load TIO Register" is not tested since it is 
not used in the 2100-Series environment. 

All STATUS- 1 and STATUS- 2 word indications are forced except for the 
following* 
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I/O program error 

Access not ready during data operation 
Drive fault 
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I ! SECTION ! 

i PROGRAM DESCRIPTION ! + 

i i ii : 


2- 1 . GENERAL ORGANIZATION 

The diagnostic is divided into four areas : 

* Initialization (Diagnostic Conf igurat ion) 

* Start 

* Test Sections 

* Error Summary 

The test sections are divided into steps which describe tests 
performed by the diagnostic. A list of possible causes for errors 
that occur* during that particular step, are given immediately 
following each step. 

The following paragraphs give a detailed description of each area. See 
Appendix D for a flowchart of the diagnostic organization. 


2-2. INITIALIZATION (DIAGNOSTIC CONFIGURATION) 

The initialization (INIT) area configures the diagnostic by ensuring 
that all I/O instructions contain the appropriate select code for the 
controller interface and determines which DMA/DCPC charnel has been 
selected. The operator enters the controller select code (bits 5-0) 
and DMA channel identification (bit 14, clear for DMA channel 6 and 
set for DMA channel 7) into the Switch Register in the diagnostic 
configuration sequence. 

The diagnostic uses the INIT area as a write buffer during execution 
if only 16K of memory is available. Thus the diagnostic must be 
reloaded before reconfiguration can be accomplished if any writes have 
been attempted to the disc during the current diagnostic run. If more 
than 1 6K of memory is present the diagnostic does not have to be 
reloaded before reconfiguration. 

Note: Reconfiguring is required only if the controller interface is 

moved to a different I/O select code or a different DMA/DCPC 
charnel is to be used. 


2-3. START 

The entire START area is considered as step zero. The START area of 
the diagnostic performs the followings 

a. Outputs the preamble (H0 79XX/I3037 DISC MEMORY DIAGNOSTIC). 
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b. Initializes trap cells by placing 1060XX (XX = trap cell location) 
in location 2 through 77 (octal). When an interrupt occurs on an 
I/O select code channel not used by the diagnostic, a halt 1 060XX 
occurs. The value in .the P-register is the memory address in the 
diagnostic at the time of the interrupt. The diagnostic is in 
need of repair and should be reloaded if the value in the 
P-register is equal to XX plus one for a halt 1060XX. If the halt 
is 106005 the problem is probably due to either a parity error or 
a memory protect violation. To determine which of the two 
problems it is, place 102505 (octal) (LI A 5) into memory location 
5. Set the P-register equal to 000005 and press RUN. The 
computer should halt with 106006 displayed. A parity error is 
implied if bit 15 of the A-register is set, otherwise, a memory 
protect violation occurred. Bits 14-0 of the A-register indicate 
the address of the location in error. (A memory protect error 
probably indicates a CPU hardware error since the diagnostic does 
not use the memory protect feature.) 

c. Initializes variables used in the diagnostic. 

d. Tests the FIFO (First-In First-Out) buffer on the interface card 
by issuing a clear command from the interface to the controller. 

If the command is accepted and acknowledged correctly, the FIFO 
counter on the interface is reset and the FIFO test begins. If 
the command is not accepted, an El 03 DISC SUBSYSTEM DOES NOT 
RESPOND message is output. See Appendix A for possible causes of 
these errors. The FIFO test consists of entering numbers from 
-(N-l) to zero, where N = the number o t levels in the FIFO. This 
number is determined by the diagnostic and will be either three or 
16, depending on the revision of the interface card used. Values 
are then read back from the FIFO and checked to determine that 
they are the correct values. If an error occurs message El 27 
INTERFACE FIFO MALFUNCTION is output indicating a bad FIFO or FIFO 
counter on the interface card. 

e. Tests the ability of the CPU to set and clear the controller 
channel flag on the disc interface card. 

f. Performs a screen test (sets channel flags on all other channels 
from 10 thru 77 (octal) except that of the disc controller and 
determines if the controller channel flag is affected). 

g. Tests interrupt operation of the disc interface card, but does not 
test the interrupt chain. The interrupt system is temporarily 
turned on, but is not used at any other time during the 

diag nost ic. 

h. Clears attention on all drives and waits for all units to be 
ready, which is indicated by the two least significant bits of the 
STATUS-2 word from each unit. 

i. Requests status from all possible units to determine the drive 
type and status of each drive. 


2-2 



Program Description 


fc 1. Issues a seek to units that are ready and an address record to all 
others in order to clear any seek status that the drive might 
have • 

k. Performs bit 2 dialogue if Switch Register bit 2 is set. Bit 2 
dialogue outputs message HI40 ENTER* (U)NIT, (?) ERRS, ( H) EAD, 
(OUTPUT, (P)ATT, (S)OFT,(C)YL, (M)CPU, (E)XIT and allows the operator 
to change the areas specified. Exits bit 2 dialogue when (E)XIT 
is typed in response to message H25 WISH TO CHANGE?. (Refer to 
Appendix B, BIT 2 DIALOGUE for more information.) 

l. Branches to operator design (OPDSN, test section 60 area of the 
diagnostic if Switch Register bit 3 is set. The OPDSN area allows 
the operator to write his own programs to test portions of the 
disc subsystem. (Refer to paragraph 3-5 for further details.) 

m. Checks that the first unit listed in the unit table is present. 

n. Controls test section execution and outputs the pass message. 


2-4. TEST SECTIONS 

The following paragraphs describe the six test sections in the 
diagnost. ic . 


2-5. TEST SECTION I . This section of the diagnostic tests controller 
functions by performing short writes and reads, and executes the 
interactive tests (steps 3 thru 20) when Switch Register bit 4 is set. 
The interactive tests check operations that relate to pack addressing 
and tests the front panel switches on the drive. The tests occur in 
the following sequence* 


STEP DESCRIPTION 

1 Gets and checks status for zero to ensure that a normal 
complete is returned and that no unexpected status conditions 
occurred. 

2 Issues a recalibrate to the drive to ensure that the heads 
are positioned correctly. Check the following for possible 
cause of errors* 

a. Servo board 

b. Track follower board 

Note* Skip to step 21 if Switch Register bit 4 is clear. 
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3 


4 


Asks operator to set drive FORMAT switch (FORMAT switch may 
already be set). Checks to see that FORMAT bit (STATUS-2 
word, bit 5) is set. Check the following for possible cause 
o f errors * 


a. Drive format switch 

b. Harness 

c. I/O sector board 

d. Data cable may not be properly attached if WAC fault 
resul ts . 

e. Preamp 

f. Drive control board 

g. Mother board 


Writes one track of random data on cylinder zero. Sets 
protect bit in preamble of each sector. Reads the last 
sector written on the track and compares it against the 
values written onto it. Verifies all the sectors on the 
track. Check the following for possible cause of errors* 


a. If 7905 and heads 0 and 1, and weak upper index pulse* 


(1) Transducer clearance too great 

(2) Transducer may be weak or faulty 

(3) I/O sector board 


b. If 7920 or head 2 of 7905, may be the track follower 
board. Execute the following OPDSN program to verify 
this * 


SK,X 

RF 

DR, 0,2 
LP 


Seek to cylinder X. 

Read a full sector. 

Display Read Buffer words 0, I, 2. 
Loop on program. 


The expected result is* 0000* 100376 


CYL HD/SEC 


where 100376 = sync word, CYL = X, and the HD/SEC = the 
head and sector addressed by the seek. This result should 
be the same on all lines. To halt the program, toggle 
Switch Register bit 3. 


2-4 



Program Description 


5 Writes one track of random data on cylinder one with the 
defective cylinder bit in the preamble set. Attempts to read 
the track in step 7. 

6 Asks operator to clear drive FORMAT switch. Checks to see 
that FORMAT switch bit (STATUS-2 word* bit 5) is clear. Bit 
5 set indicates the switch may be defective. Check the drive 
FORMAT switch for possible cause of errors. 

7 Reads last sector of cylinder one which was written in step 5 
and checks for the defective track indication in the STATUS-1 
word,. (STATUS- 1 word is 0304 XX (octal), where XX = unit 
number of the current drive.) 

8 Attempts to write on cylinder zero and checks the STATUS- 1 
word for an indication of an attempt to write on a protected 
track. This track was flagged protected in step 4. 

(STATUS-1 word is 0530XX (octal), where XX « unit number of 
current drive.) 

9 Seeks to cylinder zero and issues an initialize data command 
to the controller. Before executing the command, the 
controller checks to see that the drive FORMAT switch is set 
and the drive PROTECT or the READ ONLY switch is clear. The 
FORMAT switch is off (operator should have cleared it in step 
6) and a STATUS-2 error should be returned from the 
controller to the diagnostic as the termination status In the 
STATUS- 1 word. Any other status will result in an error 
message being output. 

10 Asks operator to set drive FORMAT switch. Writes random data 

on cylinder zero and checks that the write attempt on the 
protected track with the FORMAT switch set is possible. 

It Initializes each track that is accessed by any of the heads 

in the head table for the unit specified. Each track 
initialized in this step is verified in step 12 before the 
next track is initialized, 

12 Verifies each track initialized in step It. 

13 Asks operator to place drive RUN/STOP switch in STOP 
pos it ion, 

14 Checks STATUS-2 word from the drive for attention, not-ready, 
and busy bits (bits 7, 1,0, respectively) set. Issues a 
seek to check that the controller sets the controller channel 
flag on the interface card immediately if the disc drive is 
not ready. This step reports a status error when looped. 
Check the I/O Sector board for possible cause of errors'. 
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15 Asks operator to place RUN/STOP switch in the RUN position. 
Clears controller channel flag on the interface card and 
waits for the controller to set it. Requests S1ATUS-2 word 
from the drive and checks that bit 3 of the STATUS-2 word 
(first status) is set indicating the heads have been loaded. 
Check the Drive Control board for possible cause of errors. 

16 Asks operator to set the drive READ ONLY switch if the 
current unit is not a 7905 or 7906 Drive, otherwise set 
UPPER/LOWER DISC PROTECT switch to correspond with the heads 
which are in the head table for the unit specified. (Steps 
16 thru 19 are repeated if all heads are selected and if the 
unit specified is a 7905 or 7906 Drive.) Check the follow- 
ing for possible cause of errors: 

a. Harness 

b. I/O Sector board 

17 Performs a seek operation to cylinder zero and requests 
status from the drive. Checks for protect bit (STATUS-2 
word, bit 6) set. The protect bit should be set from step 
16. The UPPER/LOWER DISC PROTECT switch on a 7905 or 7906, 
or the READ ONLY switch on a 7920 or 7925 is probably 
defective in case of errors. 

18 Attempts to write data on the disc and checks that data was 
not transferred. Checks for STATUS-2 error. See step 17 for 
possible cause of errors. 

19 Asks operator to clear appropriate drive DISC PROTECT (7905 
or 7906) or READ ONLY (7920 or 7925) switch. See step 17 
for possible cause of errors. 

20 Sets file mask to cylinder mode and asks operator to press 
PRESET. If the PRES Ef functions properly and the computer 
interface jumper is set correctly (i.e., so that pushing 
PRESET will cause the controller to reset), the controller 
will be reset and the file mask in the controller will be set 
to zero indicating the drive is in surface mode rather than 
cylinder mode. This Is checked by writing two sectors 
starting at the last sector on a track and checking the 
status for an end of cylinder indication (STATUS- 1 word is 
006000 (octal)). Errors during this step may be the result 
of a defective PRESET switch or the preset jumpers may be set 
incorrectly. Check the following for possible cause of 
errors* 

a. See that interface jumper is positioned such that PRESET, 
when pressed, issues a CLEAR command to the controller. 

b. Defective PRESET switch 

c. Device Controller board 
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21 


22 


23 


Seeks to cylinder zero. After the seek is complete, seeks to 
the last cylinder on the unit specified. Checks that the 
busy bit (STATUS- 2 word, bit 0) is set. The check occurs 
approximately 2 msec after the seek is issued to the last 
cylinder. (The busy bit should be set since the head 
positioner on the drive should still be seeking to the last 
cylinder.) Check the following for possible cause of errors, 
if the head positioner moves, but the busy bit is clear* 

a. Device Controller board 

b. I/O Sector board 

c. Drive Servo board 

Check the following for possible cause of errors, if the arm 
does not move* 

a. I/O Sector board 

b. Drive Servo board 

Issues a recalibrate from the last cylinder. Check the 
following for possible cause of errors* 

a. Seek times too fast as set on the drive Servo board 

b. Track Follower board 

c. Drive Servo board 

d. A faint high pitched sound may indicate a faulty coil. 

e. Carriage (linear motor) problems 

f. Servo code on servo service 


Seeks to the following illegal disc addresses and issues a 
status command after each seek to check that the seek check 
bit (STATUS-2 word, bit 2) is set. 


DRIVE 

CYLINDE RS 

HEAD 

SECTOR 


7905 

411/414/442/474 

3 

48 


7906 

411/414/442/474 

— 

48 


7920 

823/830/886/950 

5 

48 


7925 

823/830/886/950 

9 

64 


Check the 

Drive Servo board 

for possible cause 

of errors. 

the carriage moves and crashes into 

the crash 

stops. 

Check the 

following, if the 

carr iage 

does not 

move: 


a. I/O Sector board 

b. Error Correction Code (ECC) board 
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c. Device Controller board 

d. Microprocessor 

e. Interface card 

24 Seeks to the first entry in the cylinder table and writes one 
sector of random data at sector zero. This data is read in 
steps 2o and 36. This is the first write performed in the 
diagnostic if Switch Register bit 4 is clear. Check the 
following for possible cause of errors* 

a. Reformat the cartridge/pack. 

b. HD/SEC compare errors may indicate a defective data 
cable . 

c. WAC fault indicates the data cable is not connected or a 
defective head 

d. Drive control 

e . Preamp 

25 Writes two sectors beginning at sector 7 of the same track as 
in step 24. 

26 Reads one sector at sector zero and compares against data 
that was written in step 24. 

27 Reads two sectors beginning at sector 7 and compares against 
data that was written in step 25. The read without verify 
command is used. (This step is skipped if this cylinder is 
flagged defective or spare and Switch Register bit 0 is set.) 

Note* Skip to step 31 if heads 0 and 1 are not in the head table for 
the unit specified. 

28 Issues a set file mask to the controller to select cylinder 
mode in the drive. Write four sectors beginning at sector 
45, head 0, and the first cylinder in the cylinder table. If 
a status check reveals an end of cylinder error, it is 
probable the set file mask command failed, or the file mask 
flip-flop in the controller, which designates cylinder mode, 
is not functioning properly. Check the Device Controller 
board for possible cause of errors. 

Note* Skip step 29 if all heads for the unit specified are not in the 
head table. 
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29 Verifies the sectors listed below. Each group starts at cyl- 
inder, head, and sector zero. An end of cylinder (STATUS-1 
word, bits 11 and 10 set) from the controller should be indi- 
cated only for the EOC sectors listed. (Cylinder mode was set 
in step 28.) 

DRIVE SECTORS VERIFIED EOC 

7905 1/2/4/8/16/32/64/128/144/145 145 

7906 1/2/4/8/16/32/64/128/192/193 193 

7920 1/2/4/8/16/32/64/128/240/241 241 

7925 1/2/4/8/16/32/64/128/432/433 433 

Check the Device Controller board or the ECC board for 

possible cause of errors. 

30 Reads the four sectors written in step 28 and compares the 
data read against that which was written. 

31 Writes and then reads one sector beginning at sector 7 with 
DMA/DCPC off. A data overrun error will occur on both the 
read and the write which is indicated by STATUS-1 word, bits 
11, 10, and 9 set. Check the following for possible cause of 
errors * 

a. Computer interface card 

b. Device Controller board 

Note: Skip step 32 if the last head for the unit specified is not in 

the head table. 

32 Write four sectors of random data beginning at sector 45 on 
the last head for the cylinder. Checks status for an end of 
cylinder condition (STATUS-1 word* bits 11 and 10 set). 

33 Issues illegal commands to the controller. Checks status for 
an illegal, op code indication (STATUS-1 word, bit 8 set). 
Check the following for possible cause of errors: 

a. Device Controller board 

b. Microprocessor 
c • ICC boa rd 

d. Computer interface card 

Note: Skip step 34 if the last head for the unit specified is not in 

the head table. 

34 Reads four sectors beginning at sector 45 on the last head 
for the cylinder. Checks status for an end of cylinder 
condition (STATUS-1 word, bits 11 and 10 set)'. Data in 
sectors 45, 46, and 47 is compared against that written in 
step 32. 
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35 Checks the first cylinder in the cylinder table and verifies 
that sector addresses on each sector of the track are correct 
for each head in the head table for the unit specified. 

Check the following for possible cause of errors* 

a, 1/0 Sector board 

b. Microprocessor 

36 Seeks to the last cylinder available (cylinder zero if first 
entry in cylinder table is the last cylinder) then issues a 
seek to the first entry in the cylinder table and immediately 
follows this with a Read command without waiting for the flag 
to be set on the controller channel. The controller should 
see a command waiting for it as it is about to set the flag 
on the controller interface card. Instead of setting the 
flag, the controller should take the Read command waiting on 
the controller interface and execute it. The flag on the 
interface should not be set until the Read command is 
complete. The data read is compared against that written in 
step 24. Check the following for possible cause of errors* 

a. Device Controller board 

b. Computer interface card 

Note* Skip step 37 if heads 0 and I are not in the head table. 

37 Tests the time-out timer in the controller. Ihe first part 
of the test sets the file mask in the controller to cylinder 
mode and waits one second. The controller will not poll 
alter receiving the set file mask command. The diagnostic 
then writes two sectors beginning at the last sector of a 
random track and checks that a normal status is returned 
indicating the timer did not time-out and that the file mask 
was not reset. 

The second part of the test sets the file mask in the 
controller to cylinder mode and waits 2.8 seconds. The 
controller will not poll after receiving the set file mask 
command and should time-out after the 2,8 seconds. The file 
mask in the controller is reset when the time-out occurs, 
which puts the controller back into surface mode. Following 
the wait, the diagnostic writes two sectors beginning at the 
last sector of a random track and checks that an end of 
cyl inder condition is returned indicating the timer timed-out 
and the file mask was reset. Check the following for 
possible cause of errors* 

a. Device Controller board 

b. Incorrect configuration of Diagnostic Configurator. Bits 
15-12 of memory location 115 (octal) should be as 

fo 1 lows * 
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Note * 
Note * 
38 


39 


Note s 


01 1 1 

for 

2100A/S 

1000 

for 

21 MX 

M-Ser ies 

1001 

for 

21 MX 

E- Series 


Skip to step 45 if the SPD (spare, protect, and defective) 
field of either of the first two entries in the cylinder table 
do not equal zero, or if the drive FORMAT switch is off. 

Skip to step 39 if the first two entries in the cylinder table 
are equal and the SPD field equals zero and the FORMAT switch 
is on • 

Forces cylinder compare error. Performs a Read Full Sector 
at sector zero of the second entry in the cylinder table. 
Writes the full sector read onto sector zero of the first 
entry in the cylinder table. Reads sector one of the first 
entry in the cylinder table. Since the controller verities 
the sector immediately preceding the sector to be read, a 
cylinder compare error (STATUS- I word, bits 10, 9, and 8 set) 
should occur (an incorrect cylinder address was placed into 
sector zero). The cylinder address in sector zero is 
corrected before proceeding to the next step. Check the 
following for possible cause of errors* 

a. Device Controller board 

b. Microprocessor 

Forces a head-sector compare error with a bad sector address. 
Performs a Read Full Sector at sector one of the first entry 
in the cylinder table. Writes the full sector read onto 
sector zero of the same cylinder. Reads sector one ol the 
first entry in the cylinder table. Since the controller 
verifies the sector immediately preceding the sector to be 
read, a head-sector compare error (STATUS-1 word, bits 11 and 
8 set) should occur (an incorrect sector address was placed 
into sector zero). The sector address in sector zero is 
corrected before proceeding to the next step. Check the 
following for possible cause of errors* 

a. Device Controller board 

b. Microprocessor 

c. I/O Sector board 

d’. Track Follower board 

Skip to step 41 if heads 0 and 1 are not in the head table. 
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40 Forces a head-sector compare error with a bad head address. 
Performs a Read Full Sector at sector zero, head one of the 
first entry in the cylinder table, Writes the full sector 
read onto sector zero, head zero of the first entry in the 
cylinder table. Reads sector one, head zero of the first 
entry in the cylinder table. Since the controller verifies 
the sector immediately preceding the sector to be read, a 
head-sector compare error (STATUS-1 word, bits 11 and 8 set) 
should occur (an incorrect head number was placed into 
sector zero). The head number in sector zero is corrected 
before proceeding to the next step. Check the following for 
possible cause of errors* 

a. Drive preamp 

b. Drive Control board 

c. I/O Sector board 

41 Forces a correctable data error. (The error correction 
circuitry will correct up to a 32-bit burst error (i.e., the 
distance between any two bits in error is less than or equal 
to 32 bits) in each sector.) Reads two full sectors from the 
first entry in the cylinder table. Selects a random location 
N (0 < N < 255) in the buffer of the first of two consecutive 
words to be modified. Replaces these two words with two 
random words which are different from those originally there. 
Writes into the two sectors read from with a Write Full 
Sector of 278 words. Reads the same two sectors. Checks 
status for a possibly correctable data error (STATUS- 1 word, 
bits 11, 10, 9, and 8, set). Checks that the syndrome 
returned would correct the error. (The syndrome returns 
seven words from the error correction circuitry to correct 
the data error.) The sectors are corrected before proceeding 
to the next step. Check the following for possible cause of 

e rrors * 

a . ECC board 

b. Microprocessor 

42 Forces an uncorrectable data error (an error not correctable 
by the error correction circuitry). This step is basically 
the same as step 41 except four consecutive words in one of 
the two sectors are replaced by random words. Checks status 
for an uncorrectable data error (STATUS-1 word, bit 11, set). 
Check the following for possible cause of errors* 

a. ECC board 

b. Microprocessor 

Note* Skip to step 45 if the two tracks selected in step 43 are 
equal, or if the SPD field of either track is not zero. 
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43 Tests sparing. Selects two random tracks A and B. Sets file 

mask to surface mode, no spare and no auto seek. Initializes 
track B defective with address A. Initializes track A spare 
with address B. Verifies track B (should be defective). 
Verifies track A (should get illegal access to spare track). 
Sets file mask to surface mode, sparing, and no auto seek. 
Writes a random sector through defective track B to spare 
track A. Reads back and checks. Sets file mask to surface 
mode, no spare, and no auto seek. Initializes track B. 

Reads from track A using false B address and checks data. 
Initializes track A. Check the following for possible cause 
of data errors* 

a. Device Controller board 

b. Microprocessor 

c. ECC board 

45 Forces unit unavailable status. Issues a seek to unit 11. 
Checks status for a unit unavailable status (S1ATUS-1 word, 
bits 12, 10, 9, and 8, set). Check the following for 
possible cause of errors* 

a. New firmware (dated after 9/7o) used with a diagnostic 
dated before 9/70. 

b. Microprocessor 

Note* Skip to step 47 if unit specified is not equal to zero, or if 
cylinder zero on the selected head is defective, or if all the 
heads for a 7905 are not in the head table, or if heads 0, 1, 

2, 3 for any other type drive are not in the head table. 

46 Tests cold load read on unit zero. Selects a random cylinder 
from the drive, or if Switch Register bit 6 is set, selects a 
random cylinder from the cylinder table. Selects a random 
head (0-3) from the head table and selects a random sector. 
Reads from cylinder zero and the head and sector selected 
above. Seeks to the cylinder selected above. Issues a Cold 
Load Read to the selected head and sector. Compares the two 
buffers to check that data read is the same in both 

ins tances . 

Note* Skip to step 47 if both heads 0 and 1 are not in the head 
table . 

The Cold Load Read resets the file mask to spare enable, 
incremental seek not allowed, and surface mode. Reads two 
sectors beginning at the last sector of the track. Checks 
for an end of cylinder condition (STATUS-1 word, bits 11 and 
10, set). Check the following for possible cause of errors* 

a. Device Controller board 
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Note * 
47 


48 
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b. Microprocessor 
c‘. ECC board 

Skip to step 48 if cylinder table (0) does not equal cylinder 
tabl e ( 1 ) minus 1 . 

Sets the file mask to surface mode, no spare, and increment. 
Writes two sectors at sector 47, cylinder table (0). Reads 
back and verifies. Reads second sector only and verifies 
(only if cylinder table (0) is not defective, or spare and 
Switch Register bit 0 is set). Sets file mask to surface 
mode, no spare, and decrement. Writes two sectors beginning 
at sector 47, cylinder table (1). Reads back and verifies. 
Reads second sector only and verifies (only if cylinder table 
(1) is not defective, or spare and Switch Register bit 0 is 
set). Check the following for possible cause of errors* 

a. Device Controller board 

b. Microprocessor 

Checks the disc address on a random sector by issuing a 
Request Sector Address after seeking to a random sector and 
checking that the head sector address returned is the same as 
that to which the seek was issued. Uses reads with cylinder 
offset = 350 microinches, cylinder offset * -350 microinches, 
clock delay = 10 nanoseconds, and clock advance = 10 nano- 
seconds. For ACCESS NOT READY DURING DATA OPERATION or CYL- 
INDER COMPARE ERROR, check the following: 

a. Servo board 

b. Track follower 

c. I/O Sector board 

Check the following for possible cause if data errors occur* 

a. Current cartr idge/pack previously formatted on misaligned 
drive 

b. Device Controller board 

c. Preamp 

d. Drive Control board 
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2-6. TEST SECTION 2. This section writes and reads back patterns 
checking for bad packs, or marginal heads. The tests occur in the 
following sequences 

Note* The steps in test section 2 are performed for each pattern in 
the pattern table. The direction to follow through the 
car tr idge /pack or cylinder table (if Switch Register bit 6 is 
set) is reversed between each pattern. 

STEP DESCRIPTION 

55 Selects next cylinder on the cartridge/pack or In the 

cylinder table according to bit 6 of the Switch Register. 
(Only uses the twelve cylinders in the cylinder table for bit 
6 set. Uses all the cylinders on the car tr idge/pack for bit 
6 clear.) Performs a seek operation. 


Note* Skip to test section 3 if Switch Register bit 5 is set. 


Note* Execute steps 5o and 59 for each head selected before selecting 
the next cylinder in step 55, 


56 Writes a given pattern, derived from the pattern table onto a 

track. (See Appendix B, (P)ATT.) 

59 Reads the track written in step 56. Compares the pattern 

read against the pattern from the pattern table. A read with 
offset = 350 microinches is used initially (normal read on 
any retries) for the ninth pattern. A read with offset * 

-350 microinches is used initially (normal read on any 
retries) for the tenth pattern. Check the following for 
possible cause of errors: 


a. Device Controller board 

b. Preamp 

c. Drive Control board 

d. Noisy track follower 

e. Servo board if the single cylinder seek time is greater 
than 5.2 milliseconds. 

f. Power board (7905/7906) or PMR (7920/7925) 

Note* Return to step 55 until all cylinders to be tested have been 
tested for all ten patterns. 
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tote: Timing message giving the average single cylinder seek time is 

output if Switch Register bit 12 is set. 

In general, the following are possible causes of errors which may 

occur in test section 2* 

a. A faulty head will usually cause errors on the high numbered 
tracks . 

b. The preamp may cause random data errors for a particular head, 
however all the heads may be faulty. 

c. The Drive Control board may cause random data errors on any head. 

d. Repeated data errors on a specific cylinder, head, and sector 
indicate a bad spot on the media. If errors occur on all the 
heads a defective servo code (needs re-servo formatting) is 
indicated. 

e. A WAC fault may indicate any part (boards, data cable, heads, 
etc.) in the write path circuitry is faulty, and is probably heat 
sens it ive . 

f. A Timeout fault may indicate a heat sensitive power board. 


2-7. TEST SECTION 3. This section writes and reads back random data 
from random locations to check seek and data transfer operations. The 
random location includes a head randomly selected from the head table. 
A cylinder number is randomly selected from the cylinder table for 
Switch Register bit 6 set and from the drive for bit 6 clear. The 
tests occur in the following sequence: 


Note* Perform steps 70 through 72, 1024 times (64 times if Switch 
Register bit 5 is set). 


STEP DESCRIPTION 

70 Seeks to a random cylinder, head, and sector. Generates a 

random word count between 1 and 1023. Checks the word count 
and ensures (by continually reducing the word count by a 
factor of 2) that a write of this magnitude will not exceed 
the end of the cylinder. A buffer of random data of this 
length is now generated. 
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71 Writes the buffer of random data and random length into the 
random locations chosen in step 70. 

72 Reads and compares against data written in step 71. Word 
count is incremented if sector fill was necessary on write in 
step 71. Check the following if errors concerning cylinder, 
head, and sector information, occur: 

a. Servo board 

b. Track Follower board 

c. Servo head lead 

d. Inspect the Servo code 

Check the following if data errors occur* 

a. Device Controller board 

b. Computer interface card 

In test section 3, AGC faults may be caused by the Track Follower 
board, or by the Servo board. 


2-8, TEST SECTION 4. This section fills the pack full of check summed 
data and checks the checksum of the cylinder, head and sector number. 
Each sector is checksummed separately. The entire sector sums to 
zero. The first two words sum to the cylinder number. The next two 
words sum to the head/sector number. 


Note* Use all cylinders on the cartr idge/pack if Switch Register bit 
6 is clear and use the twelve cylinders in the cylinder table 
if bit 0 is set. 


STEP DESCRIPTION 

75 Seeks to the next cylinder according to Switch Register bit 

6 . 

7o Generates a buffer of checksummed data and writes the check- 

summed random data onto the entire track. Note: Execute 

steps 79 and 80 only when the current cylinder also occurs 
in the cylinder table and the current head is head 2. 
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79 Reads sector zero with offset * +63 (decimal) . Checks only 
the STATUS-2 word to ensure a drive fault did not occur. 
Check the track follower for possible cause of errors. 

80 Read sector 33 with offset = -63 (decimal). Checks only the 
STATUS-2 word to ensure a drive fault did not occur. Check 
the track follower for possible cause of errors. 


Note* Return to step 76 until all heads in the head table have been 
selected. Then return to step 75 to select a new cylinder 
until a]l cyl inders have been selected. 


Note* Data is accumulated to calculate average random cylinder seek 

time if Switch Register bit 12 is set in steps 81 and 82 and if 
Switch Register bit 5 is clear. 


Note* Steps 81 and 82 are repeated 8192 times (256 times if Switch 
Register bit 5 is set). 


81 Seeks to a random cylinder, head and sector according to 
Switch Register bit 6. 

82 Reads and verifies checksummed data of one sector for the 
cylinder, head, and sector written in step 76. Check the 
following if an error concerning cylinder, head, and sector 
information occurs: 


a. 

Servo 


b. 

Track 

follower 

c. 

Servo 

head lead 

d. 

Inspect Servo code 


Check the following if data errors occur: 

a. Device Controller board 

b. Computer interface card 

In test section 4, AGC faults may be caused by the Track Follower 
board or the Servo board. Seek errors are likely to happen here 
if the Servo board has heat sensitive counting problems. 
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2-9 „ TEST SECTION 5. This section runs multiple unit test if at 
least two units are present and no errors occurred for any unit in 
test section 4. The multiple unit test is not run until each unit 
under test has run through test section 4. 

STEP DESCRIPTION 

85 Checks overlapping seeks by issuing seeks to random locations 

on each drive present, one after another. As the seek is 
completed, the data read is checked as in step 82 to ensure 
the checksums agree with those written in step 76. (See step 
81 for selection of the random locations.) Possible cause of 
errors is the RAM on the device controller. 


Errors only in test section 5 may indicate faulty multi-unit hook-up. 


2-10. TEST SECTION 0 (OPERATOR DESIGN). This section of the 
diagnostic is not part of the standard sequence of tests and must be 
specifically selected to execute. This section allows the operator to 
write special test routines to test specific drive functions and to 
perform multiple CPU testing. Set Switch Register bit 3 to enter this 
section. (Refer to paragraph 3-5 for detailed operator design 
procedur es . ) 


2-11. ERROR SUMMARY SECTION 

The Error Summary section is used after the diagnostic has run. To 
enter this section, load a starting address of 16000 (octal) into the 
computer P-register and press RUN. Error summary data is output 
followed by a halt 77 (octal). (Pressing RUN at this time will clear 
the error summary data and will cause a branch to memory location 2000 
(octal) and the diagnostic will begin execution.) The following is an 
explanation of what the Error Summary section will output and an 
explanation of the sample output listed at the end of this paragraph. 
The Error Summary section will output the following* 

a. Dumps the cy linder/head table. This table consists of up to 150 
different cy linder/head combinations on which data errors 
occurred, and gives the number of errors which occurred at each 
cy linder/head combination. Only those cylinders with errors are 
dumped (cylinders 734, 761, and 768 of the example are shown). 

Only the first 150 cy linder/head combinations are recorded due to 
memory space limitations, however this is adequate for any 
car tr idge/ pack whcih meets specifications. The number of data 
errors which occur for the 151 and greater cy linder/head pairs 
are accumulated and output as being the '‘OVERFLOW" amount. The 
total number of both data errors and non-data errors (i.e., NO 
FLAG, ACCESS NOT READY), which have occurred since the diagnostic 
was last started by setting the P-register to 2000 (octal), are 
output as the "ALL ERRORS". Each line dumped shows all data 
errors made on a particular cylinder 
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b. Dumps the head/sector table. This table consists of up to 150 
different head/sector combinations on which data errors occurred, 
and gives the number of errors which occurred at each head/sector 
combination. Only those sectors with errors are dumped (head 0, 
sectors 24 and 26, and head 4, sector 0 in the example). Only 
the first 150 head/sector combinations are recorded. The number 
of errors which occur for the 151 and greater head/sector pairs 
are accumulated and output as the "OVERFLOW" amount. 

c. Dumps the head/unit table. This is a 5 by 8 matrix. All data 
errors since the diagnostic was started are shown. Lines which 
show no errors are suppressed. Only those heads that had errors 
are shown. (The head number is followed by an E.) 

d. Dumps a line showing fatal errors. These are shown by the unit 
which was running when the error occurred. 

e. Dumps a line showing the number of long passes completed for each 
unit. 

f. Dumps a matrix showing the number of usable tracks for each head. 
Lines which show no use (head not selected) are suppressed. (The 
head number is followed by a C.) A track is not usable if it is 
flagged defective. 

g. Dumps a line showing if each drive meets specification (no fatal 
errors, 406 good cylinders on 7905/7906 and 815 good cylinders on 
7920/7925, cylinder zero good, and less than one data error in 
every one billion (10^) bits transferred. (Unit 0 in the example 
failed because of the fatal error that occurred.) 

h. Dumps a list of all address errors (up to 151 errors). Shown is 
the starting cylinder address (OLD C\L), intended cylinder address 
(CYL ) , actual cylinder address (ACTUAL CYL), and actual head and 
unit. These errors result when a seek completes on a cylinder 
other than where it was suppose to. 
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CYL 

HD0 

HDl 

HD2 

HD3 

HD4 

0734 

0001 





0761 

0768 

0001 




0005 

TOTAL 

0002 

0000 

0000 

0000 

0005 


OVERFLOW-OOOO; ALL £RRGR=0009 


HEAD 00 SECTORS 24 -31 0001 0000 0001 0000 0000 0000 0000 0000 
HEAD 04 SECTORS 00 -07 0005 0000 0000 0000 0000 0000 0000 0000 


HEAD 

UNIT 0 

UNIT 

1 UNIT 2 

UNIT 3 

UNIT 4 

UNIT 5 

UNIT 6 

UNIT 

00-E 

0002 

0000 

0000 

0000 

0000 

0000 

0000 

0000 

04 -E 

0000 

0005 

0000 

0000 

0000 

0000 

0000 

0000 

FATAL 

0001 

0000 

0000 

0000 

0000 

0000 

0000 

0000 

PASS 

0010 

0010 

0000 

0000 

0000 

0000 

0000 

0000 

00-C 

0821 

0823 

0000 

0000 

0000 

0000 

0000 

0000 

01-C 

0823 

0823 

0000 

0000 

0000 

0000 

0000 

0000 

02-C. 

0823 

0823 

0000 

0000 

0000 

0000 

0000 

0000 

03-C 

0823 

0823 

0000 

0000 

0000 

0000 

0000 

0000 

04 -C 

0823 

0823 

0000 

0000 

0000 

0000 

0000 

0000 

OK? 

NO 

OK 







OLD 


ACTUAL 







CYL 

CYL 

CYL 

HEAD UNIT 





0822 

0821 

0819 

00 1 






0793 

0792 

0796 

00 1 






0792 

0791 

0793 

00 1 






0791 

0790 

0784 

00 1 







2- 1 2 . DIAGNOSTIC MESSAGES 

Two types of messages are output by the diagnostic* error and 
information messages. Error messages are used to inform the operator 
when the interface, controller, or drive fails to respond properly 
to a command sequence. The diagnostic outputs an error summary 
information message, H65, at the end of each pass: 

H65 LONG (SHORT) PASS XXXX, HEAD YYYYYYYYY , UNIT X, AAAA ERRORS- 
BBBB SOFT (, MULTI -UNIT ) 

where: AAAA = Fatal and non-fatal errors. 

BBBB = Non-fatal errors. 


Errors which would probably cause an operating system to irrecover 
ably fail or have to be restarted are fatal errors. Examples of 
this type of error are as follows: 

a. No flag from the controller indicating completion of a command 
from the CPU. 
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b. An uncorrectable data error (fatal only if repeated five consec- 
utive times on the same sector) . (This may be the result of 
errors introduced during a write function.) 

c. Reading a sector of known data which has an error in it, which 
is not reported as a data error by the disc subsystem. 

Non-fatal errors are divided into "data" and "non-data" errors. Data 
errors are those which cause the controller to return either a 
possibly correctable data error or an uncorrectable data error status. 
When you suppress soft errors (Appendix B, step f) , you are suppress- 
ing non-f atal data errors (non-data errors are still reported) . Data 
errors that occur frequently at a given location on the disc (hard 
errors) are probably caused by a bad track on the disc media and 
should be flagged defective (refer to example 8 in the Helpful Hints 
portion of this manual) . 

Information messages are used to inform the operator of the progress 
of the diagnostic or to instruct the operator to perform an operation. 
If an associated halt occurs, the operator must press RUN to continue 
execution of the diagnostic. The printed message will be preceded by 
the letter E (error) or the letter H (information) and a number (in 
octa 1 ) . 

All messages are suppressed by setting Switch Register bit 11 and 
information messages are suppressed by setting Switch Register bit 10. 

A halt code summary and complete explanations of individual error 
information messages appear in Appendix A. 

2-13. EXECUTION TIME 

Time to execute a pass will depend on operator intervention, error 
retries, and message suppression. Approximate execution times for a 
long pass of the diagnostic (040001 (octal) loaded in S-register as 
desired options) and all heads selected are given, below for the 
various disc drive, CPU, and memory size configurations: 


+ + 

DRIVE | 7905 I 7906 I 7920 1 7925 I 


MEMORY SIZE 
(BYTES) 

— — — — - 

1 

1 32K 

1 

i 64K 

f 

1 

1 32K 

-1- . 

I 

i 64K 

4-_ __ — _ — 

f 

1 

I 32K 

4-— — — . . 

1 

1 64K 

JL—> ______ 

h 

i 

1 32K 

l 

i 64K 

CPU 

■ — — — — — ■ 
I 

1 

i 

1 

I 

1 

i ! 

1 1 

i i 

1 

2100A/S 

1 1 
! 0:40 

i 1 

1 I 

10:33 

i 

1 0:52 

j 

1 

1 0:40 
1 1 

1 

j 1:45 i 
| 

1 1 
i 1:10 1 
1 1 

1 1 
1 3:53 

| 

I 2:46 

2105/08/12 

j 0:38 , 

1 

| 0 : 29 

i 0:47 

0:35 | 

1:43 

1:08 j 

3:45 j 

2:27 

2109/13 

10:37 1 
i 1 

0:28 1 
i 1 

1 0:45 

1 

i 0:33 

1 1:25 
1 1 

i 0:58 | 
1 1 

1 3:09 1 
1 

1 2:05 

NOTE: Times 

are given as, hour s: minutes . 
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! ! SECTION J 

J OPERATING PROCEDURE ! + 

: i iii j 


3- 1 . DIAGNOSTIC OPERATING PROCEDURES 

A flowchart of the operating procedures for loading and starting the 
Diagnostic Configurator and this diagnostic is provided in figure 3- 1 
on the following page. Refer to the Diagnostic Configurator Reference 
Manual, part no. 02100-90157, or to the Basic Operating Procedures at 
the front of this manual, for the procedures specified in figure 3-1. 

Table 3-1 is used in conjunction with the flowchart to configure the 
diagnostic program. 

Table 3-2 (paragraph 3-3) is used during execution of the diagnostic 
to allow the operator to select desired options. 


Note : 


If the diagnostic has been run, it can only be reconfigured 
if 40K-bytes or more of memory is available. 
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Figure 3-1 . 


Load/Start Procedure Flowchart 
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Table 3-1. Select Code and DMA Channel Option 


BIT 

COMMENT 

0-5 

Set to select code of I/O channel containing 


the interface PCA. 

*14 

Set for DMA channel 7? clear for DM/ channel 6. 

Note * 

Bits 6-13, and 15 are spares. 


3-2. PREPARATION FOR DIAGNOSTIC RUN 

When running the diagnostic, use a scratch car tr idge/pack if data on 
the current cartridge/pack is to be saved since all information on the 
cartridge/pack used will be lost. 

On a 7905/7906 Drive, set the LOWER DISC PROTECT switch if data on the 
fix€;d disc is to be saved. 


3- 3 . PUNNING the diagnostic 

a. Load a starting address of 2000 (octal'} into the P-register. 

b. Select desired options from table 3-2 by setting the appropriate 
bits of the Switch Register. 

c. If Switch Register bit 2 is set (bit 2 dialogue) message H140 
ENTER* (U)NIT, ( ? ) ERRS, (H)EAD, (O)UTPUT, (P)ATT, (S)0F1 , (C)VL, 

(M)CPU', (E)XIT is output and the operator is allowed to change the 
specified areas. Type E in response to message H25 WISH TO 
CHANGE? to exit the bit 2 dialogue. Refer to Appendix B, BIT 2 
DIALOGUE, for more information. 

d. If Switch Register bit 3 is set, control is given to the operator 
design (OPDSN) portion of the diagnostic (refer to paragraph 3-5). 

e. After the diagnostic has run, a summary (refer to paragraph 2-11) 
of all data errors may be output by performing the following* 

(1) Load a starting address of 160O0 (octal) into the P-register. 

(2) Press RUN. 
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Table 3-2. Diagnostic Switch Register Options 


BIT 

COMMENT 

0 

Allow defective and spare tracks (i.e., tracks 
flagged spare or defective will not cause an error 
when the diagnostic is run) and flag a track 
defective in step 1 2 or in step 90 if five 
consecutive attempts to verify that track are 
unsuccessful, when set. 

1 

Skip to end of current test section when set. 

2 

Allow operator to alter the unit table, unit removal 
threshold, head table, determine status heading, 
alter pattern table, change decision on printing 
soft errors alter cylinder table, and decide whether 
or not MCPU mode is entered, when set. (Refer to 
Appendi x B. ) 

3 

Enter operator design portion (OPDSN, test section 
6) of the diagnostic, when set. 

4 

Execute test section 1, steps 3 thru 21 , when set. 
These steps are not performed elsewhere in the 
program since operator assistance is required. 

5 

Skip test section 2 and shorten test in test 
sections 3, 4, and 5. (Refer to Appendix D.) 

6 

Select cylinder numbers from the cylinder table when 
set; from all those available on drive, when clear. 

7 

Loop on current test section when set. 

8 

When set, eliminate all blank lines between messages 
output and output the pass message H 65 if an error 
occurs during a pass in which bit 10 is set’. 

9 

Halt ( 1 0201 X ) after each test section of the 
diagnostic is complete when set. Push RUN and the 
diagnostic will continue from where it left off. 

1 0 

Suppress all non-error messages (i.e., H... 
messages), when set. Exceptions are current 
operation messages when an error occurs, the 
cylinder, head, and sector where the error occurs, 
and the pass message H65 on each pass where the 
error occurs, when bit 8 is set. 
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Table 3-2. Diagnostic Switch Register Options (Cont) 


BIT 

COMMENT 

1 1 

All messages are suppressed when set. 

1 2 

Print timing messages in test sections 2 (H53 
AVERAGE SINGLE CYLINDER SEEK TIME X.XX) and 4 (H54 
AVERAGE RANDOM SEEK TIME XXXX.X, LENGTH XXXX.X), 
when set. 

13 

Loop on current step when set. 

1 4 

Program will not halt after each error when set. 

1 5 

Halt (102004) after the current step is complete, when 
set. If in OP DSN when set, the current OPDSN program 
will halt, and if bit 3 is set OPDSN instructions may be 
entered, otherwise the diagnostic will begin execution. 


3-4 „ USING THE DIAGNOSTIC AS A TROUBLESHOOTING AID 


During the execution of the diagnostic, various information and error 
messages are output by the diagnostic. These messages can be used to 
determine the cause of errors, if they are interpreted correctly. The 
following steps describe the procedures for using the diagnostic as a 
troubl eshoot ing aid* 

a. Carefully read each and every line output by the diagnostic and be 
sure you understand it. 

b. If a step number is given, turn to the explanation of that step 
which is given in section II of this manual. The explanations for 
the various steps in the diagnostic have been expanded to give a 
more thorough explanation of what is being done. In some cases it 
may be necessary to read a few steps proceeding or following the 
step in error to get a full understanding of what is being done. 
Along with this explanation, several of the steps include probable 
causes as to what might be malfunctioning. These are given 
starting with the most likely device. 

c. Turn to Appendix A of this manual for an explanation of the 
various messages output by the diagnostic. Possible causes of 
these messages are given in several cases. 

Note* It is very important to look at each of the status bits in the 
E64 message which gives the two status words obtained and the 
two values showing what they should be. Special attention 
should be focused on those bits which differ. 
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3-5. OPERATOR DESIGN PROCEDURE 

To enter test section o (OPDSN) of the diagnostic perform the 
fo 11 owing * 

a. Load a starting address of 2000 (octal 1 ) into the P-register. 

b. Set Switch Register bit 3 in conjunction with any other bits for 
the desired diagnostic options. 

c. Press PRESET (INTERNAL and EXTERNAL). 

d. Press RUN. An introductory message J, H55 ENTER INSTRUCTIONS 
(CURRENT UNIT = XX ) " is output. (XX = unit currently being 
addressed by diagnostic and to which all commands will be issued 
unless changed, by a SD, N instruction (N = new current unit)). 

Note* The units addressed in an OPDSN program are not required to be 
in the unit table. 

Note* Clear Switch Register bit 3 to give control to START area of 

the diagnostic when the current OPDSN instruction is complete. 

e* The following contain information needed to create an operator 
design programs 

(1) Enter instructions from paragraph 3-7 in the desired 

execution sequence. Commas separate fields. Fields are 
defaulted if excluded from instructions or skipped by the 
instruction . 


Example* The form 
Se ctor . 

for a seek 

command 

is SK, Cylinder, 

Head, 


SK 

Seeks 

to 

cylinder 

0, head 

0, 

and 

sector 

0. 

SK,, 1 

Seeks 

to 

cy li nder 

0, head 


and 

sector 

0. 

SK ,7 , 2 ,3 

Seeks 

to 

cyl i nder 

7, head 

2, 

and 

sector 

3. 


(2) I f an error occurs in instruction entry, the message H3 1 
INPUT ERROR is output. The erroneous entry has been rejected 
and must be typed again. 

(3) Erase present instruction entry before LINEFEED has been sent 
by using RUBOUT /DELETE. 

(4) Erase last line in input string with operator instruction EE 
(Erase Entry). Repeat the instruction N times to erase the 
last N lines. 

(5) Erase operator design program completely with operator 
instruction EP (Erase Program). 
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(6) Shorten the operator design program following an HI 6 OVERFLOW 
message with an EE or an EP operator instruction. 

(7) Labels are exactly two characters . All printing characters 
are legal. Spaces are skipped. 

(8) Add instructions to the operator design program, beginning 
from the end, with an AI instruction. 

(9) Restart operator design programs with an RI operator 
ins true tion . 


(10) The CL, CR, DS, ID, IS, RC, RD, RF , RO, RS , RW, SK, VF, WD, 
and WF operator instructions include a software status check 
unless they are followed by a SC, VS, VP, or VD operator 
instruction. The expected status for software status check 
is default status (00000000G0000YYY) for STATUS- 1 word 
( YYY * unit number) and 0AAAAAA0 00X0 0000 , where AAAAAA = 
drive type = 000010 for 7905, 000000 for 7906, 000001 for 
7920, and 000011 for 7925. X = don't care. SC allows 
expected status to be specified. VS, VP, and VD are specif- 
ic status which look for spare, protected, and defective 
tracks, respectively. 


(11) An EN, LP, or LS operator instruction will be rejected if 
undefined labels exists in the operator design program. 

(12) Field limits are as follows: 


0 < Cylinder < ZZ 
0 < Head < X 

0 < Sector < Y 

1 < Read Buffer Size < w 
1 

-63 < Cylinder Offset < +63 


ZZ = 410 for 7905/7906 and 
822 for 7920/7925 

X = 2 for 7905, 3 for 7906, 4 
for 7920, and 8 for 7925 

Y = 47 for 7905/7906/7920 and 
63 for 7925 


W = 1024 for 32K~bytes of mem- 
ory and 8192 for 64K-bytes 


< Number of Sectors Verified < 32767 


1 < Define Buffer Size < W W = 1024 for 32K-bytes of mem- 
ory and 8192 for 64K-bytes 


Limit checks are not made on Cylinder Offset. If the limits 
are exceeded, fields may merge and produce unusual results. 
To disable limit check of cylinder, head, and sector 
variables, use the DC command prior to the desired seek in 
the OP DSN program. 
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3-6. MULTIPLE CPU TESTING 

This test should be used only after each CPU has been checked out 
thoroughly with the rest of the disc subsystem in a single CPU 
envi ronment . 

Multiple CPU testing is accoinp li shed with the OP DSN command MC . The MC 
command may also be executed in a single CPU environment, however, the 
purpose of the command is to test the setting and clearing of the hold 
bit and the functioning of the WAKEUP command, which are useful only 
in a multiple CPU environment. 

Because the more complex multiple CPU protocol is not used throughout 
the program, a major portion of the diagnostic cannot be run in a 
multiple CPU environment without errors. A bit 2 option of the 
diagnostic occurs in the START area of the diagnostic and tells you 
whether or not you are in MCPU mode. The diagnostic then asks you if 
you wish to change the mode of operation. If you respond YES, it 
changes from whatever mode you are in to the other mode, (i.e., you 
are either in MCPU mode or you are not in MCPU mode). 

When in MCPU mode, the only parts of the diagnostic which may be 
executed are a small portion of the START area (excluding portions 
which send commands to the control ler) and OPDSN . OPDSN only works on 
a limited set of its regular commands when in MCPU mode. All 
unacceptable commands are rejected at the time of entry into OPDSN 
programs. (Refer to the MC instruction in paragraph 3-7 for the 
commands which may be used when in MCPU mode.) 

To exit from MCPU mode, return to the bit 2 dialogue. This may be 
accomplished by clearing Switch Register bit 3 during OPDSN execution 
or by typing FX during OPDSN program entry. To the bit 2 question 
concerning MCPU mode, respond that you wish to change by typing YES. 
This will remove you from MCPU mode. 

Note* All CPU's executing on the same disc subsystem must be in MCPU 
mode if more than one CPU is operating. 

Note* Errors in hold bit setting and clearing or faulty operation of 
a WAKEUP command are usually indicated by either SEEK CHECK 
errors in the STATUS-2 word received from the drive or by the 
messages * 

H 1 27 NEVER GOT FLAG ON WAKEUP UNIT = XX 
E63 NO FLAG 


3-7. OPERATOR INSTRUCTION LIST 


Note* Brackets in the following instruction list indicate fields that 
may be omitted. 
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I INSTRUCTION FUNCTI ON 

AI Add I nstruct ions • Allows operator to add to the 

list of instructions last executed. The 
terminating instruction EN, LP, or LS,N is deleted 
from the previous program. The AI instruction is 
undefined if the previous program has been lost 
(any of test sections I thru 5 have run). 

ARMCCC3 t , I H 3 [,SSII] 

Address Record. This instruction sets up the disc 
address in the controller. Default condition sets 
the disc address to zero. (CCC = cylinder, H = 
head, SS = sector). 

CA,LL. Call subroutine LL. This instruction transfers 

control to the subroutine LL. Subroutine LL need 
not be defined before the CA,LL instruction is 
entered into the OPDSN program. (Also see SB,LL 
and LV,LL instructions.) 

cb c , c xxxx :i c,vvn 

Compare Buffers. The indicated number of words of 
the write buffer are compared with the 
correspondi ng words of the read buffer. (XXXX = 
word count, YY = allowed number of error 
printouts). Default case is 128 words and the first 
compare error that occurs is output in message E47 
DATA WO RD XXXX IS YYYYYY SHOULD BE ZZZZZZ. If a 
data error occurs the syndrome (error correction 
information) is requested and message HI 16 DATA 
ERROR CORRECTED is output if all the errors are 
corrected. 

CC [,N] Change cylinder variable in diagnostic by iSl modulo 

number of cylinders on the currently addressed 
drive. To notify the controller of this change 
follow the CC instruction with a RL instruction. 
(Default = 1) 

CH [ ,N ] Change head variable in diagnostic by N modulo num- 

ber of heads on the currently addressed drive. To 
notify the controller of this change follow the CH 
instruction with a RL instruction. (Default * 1) 

CL Clear. A clear command is issued to the drive. 
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CP,X,Y Compare surface X with surface Y. This command is 

intended primarily for checking the transfer of one 
surface to another. It should follow all IS or TC 
instructions as a check of the transfer. All 138 
words of the sector are checked. If an error occurs 
on any cylinder a TC,CCC,X,Y instruction should be 
used to transfer that cylinder again. 

Note* The PROTECT switch should be off during the CP instruction. 

Note* The second program in example 6 of the Helpful Hints portion of 
this manual is an equivalent OPDSN program for the CP,X,Y 
instruction. 


CR I,CXXXX3 C, CH] [ , SS 3 3 3 

Cold load read. Issue a cold load read to unit 0, 
head H, and sector SS . (XXXX = word count.) 

Default head and sector is 0. Default word is 128. 
0 < H < 3 

CS [,N] Change sector variable in diagnostic by N modulo 

number of sectors on the currently addressed drive. 
This only changes the value in the processor. To 
notify the controller of this change, follow the CS 
instruction with a RL instruction. (Default * 1) 

CW *X,Y Change word X (decimal) of the write buffer to Y 

(octal). 0 < X < 1023 for 32K-bytes of memory and 
8191 for 64K-bytes 

DA Request Disc Address. The two words returned from 

the controller contain the current cylinder, head, 
and sector stored in the controller. The two words 
are placed in the first two words of the read 
buffer. To display the two words , follow the DA 
instruction with DR, 0,1. The values displayed are 
octal values. The first word is the current 
cylinder? the second word has the head and sector 
in the upper and lower bytes, respectively. 


DB C , 1 XXXX 3 C , YYYYYY C , C 3 3 3 

I 

Define Buffer. The write buffer has the indicated 
number of words filled with the indicated pattern. 
Default case fills 128 words. Default pattern 
causes each word to be random. (XXXX = word count, 
YYYYYY = pattern word in octal). 


If »C" is present the pattern is complemented in 
successive words. If "I" is present the pattern is 
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incremented in successive words. When the "C** or 
"I” option is used* the default pattern is zero. 

DC Disable checking. Disable checking for legality of 

cylinder, head, and sector addresses sent to the 
controller at run time. 

DL C,M3 Delay N milliseconds before proceeding to the next 

OPDSN instruction to be executed. 

DR , X |[ ,Y] Display Read buffer contents starting from word X 

to word Y. If Y is not given, the contents of word 
X are displayed. 0 < X < 1023 for 32K-bytes of 
memory and 8191 for 64K-bytes, 0 < Y 1023 for 
32K-bytes and 8191 for 64K-bytes, X < Y 

DS [ , [CCC] [ ,[H] [ , SS ] ] ] 

Decrement Seek. This instruction will do an ini- 
tial seek to the location specified in this in- 
struction and will decrement the cylinder by 1 
each time it is executed until it reaches cylinder 
zero. Following cylinder zero, it will seek to 
last cylinder of current unit (cylinder 410 of 
7905/7906 and cylinder 822 of 7920/7925). Default 
condition sets the disc address to zero. The ini- 
tial value CCC,H,SS is reset if the OPDSN program 
is restarted. 

DW, X [ , Y] Display write buffer contents starting from word X 

to word Y. If Y is not given, only the contents of 
word X are displayed. 0 < X < 1023 for 32K-bytes 
of memory and 8191 for 64K-bytes, 0 < Y < 1023 for 
32K-bytes and 8191 for 64K-bytes, X < Y 

EE Erase Entry. Last instruction entered into OPDSN 

program is erased. 

EN [,L1L] End. This instruction terminates operator design 

instruction entry. The label portion of this 
instruction is the start address for operator 
design execution. In the default case, the program 
will execute from the first instruction (LL = 
label). This instruction begins execution of 
operator design program. 

EP Erase Program. Erases present program and outputs 

message H55 ENTER INSTRUCTIONS (CURRENT UNIT = XX). 

EX Exit. Turns off Switch Register bit 3 and goes to 

step 1 of diagnostic when entered into the OPDSN 
program. 

FH Format all heads in head table for current unit. 

Same as FN, but for each head in the head table. 
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FN Format surface N ( N = head 0-2 for 7905, 0-3 for 

7906, 0-4 for 7920, and 0-8 for 7925). This in- 
struction is the same as: 


LB, AA 
IS , ,N 
ID 

IS, ,N 


VF , SS 

SS = 48 for 7905/7906/7920 and 
64 for 7925 

Rr ,AA,ZZ 

ZZ = 410 for 7905/7906 and 
822 for 7920/7925 


G0,LL GOTO. Branches to label LL in program. 

HT [»XXXXXX] Halt. This instruction halts and displays vaJue in 

A-register. Zero is displayed in the default case. 
(XXXXXX = display value in octal). 


ID [ , [XXXX] [ ,S] ] 

D 

p 

Initialize Data. This instruction requires that 
the FORMAT switch, in front of drive be ON to allow 
access to the sector address words on the disc. 

This command results in the disc address being 
placed in the sector currently referenced. If the 
defective track indication (D) is added to this in- 
struction each sector is tagged defective. If the 
protect track indication (P) is added to this in- 
struction, each sector is tagged as protected. If 
the spare track indication (S) is added to this in- 
struction, each sector is tagged spare. This pro- 
cess is repeated on as many sectors as the word 
count allows. The default case for a 7905/7906/ 

7920 writes 6144 words from the write buffer which 
is equal to 48 sectors of 128 words each; for a 
7925, 8192 words are written which is equal to 64 
sectors of 128 words each. (XXXX = word count.) 

IS [, [CCC] [,[H] [ ,SS] 1 1 

Incremental Seek. This instruction will do an 
initial seek to the location specified in this 
instruction (default » 0) and will increment the 
cylinder by one each time it is executed until it 
reaches cylinder XXX. Following cylinder XXX it 
will seek to cylinder 0. (Note that IS instructions 
are independent of one another when two or more are 
used in the same program.) The initial value of 
CCC,H,SS is reset if the OPDSN program is restarted. 
(XXX = 410 for 7905/7906 and 822 for 7920/7925.) 
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LB,LL Label. Associates a particular location in the 

program with a label. (LL = label). 

LP [ , LL ] Loop. (Similar to EN . ) Program starts at location 

LL, but loops to beginning of program when LP is 
executed. A program ending with LP may run indefi- 
nitely unless computer is halted, Switch Register 

bit 3 is cleared, or bit 15 is set. 

LS,N Loop on Step N. Terminates OPDSN instruction entry 

and begins execution of OPDSN program when entered 
into the OPDSN program. When LS,N instruction is 
executed, the OPDSN program is halted, Switch 
Register bit 3, is cleared, and the diagnostic 
begins execution at step 1. Execution of step N 
sets Switch Register bit 13 and the diagnostic 
loops on step N. If N is not a valid step number, 
LS will be executed without the looping feature. 

LV,LL Leave subroutine LL. This instruction transfers 

control from subroutine LL to the instruction 
following the last CA,LL instruction executed. 

(Also see SB, LL and CA, LL instructions. ) 

MC [ , [CCC] [ , [H] [ ,SS] ] 3 

Multiple CPU Check. Tests the hold bit and wakeup 
command in a multi-CPU environment. Issues a wakeup 
command to current drive to check availability. 
Performs seek to speciiied cylinder, head, and 
sector with hold bit set. Sets file mask equal to 
four which enables track sparing. Verifies one 
sector, selected during seek, without hold bit set. 
Issues a NOP (Poll) to controller. 

Note* Instruction MC without a comma (no address specified) will 

cause a random seek. Instruction MC, (with a comma) will cause 
a seek to cylinder 0, head 0, sector 0. 

Note* When executing an operator design program containing a MC 
instruction all computers must be halted, or they must be 
executing an operator design program containing only the 
following instructions: 


A I 

CS 

DR 

EP 

LP, LL 

RT , LL , X 

CA 

cw 

DW 

EX 

LS 

SB 

CC 

DB 

EE 

HT 

LV 

SD, X 

CH 

DC 

EN 

LB ,LL 

R I 

TB 
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Note* One test is to connect two or more CPU's to a common controller 
and execute the following operator design program in all the 
CPU's* 


SD f 0 

MC 

LP 


For a more extensive test, write an OPDSN program in each CPU 
which issues at least one MC command to each drive in the 
system and looping each program by ending it with the LP 
command • 


Example* 5D,0 
MC 

SD, I 

MC 


If more than one disc drive is used by 
more than one CPU (up to eight), the 
program may be placed in each CPU and all 
of them executed simultaneously as long as 
each CPU is in the MCPU mode. 


SD, <n> 

MC 

LP 


NO Nop. Issues a NOP (or end or poll) command to the 

disc. Tells the controller to continue polling. 

PR,SS Output the two character symbol SS followed by an 

integer number which is incremented each time the 
command is executed. SS may be any valid two 
characters. The increment counter is initialized 
to zero each time the OPDSN program is restarted. 


Example* LB, XX 
PR, A 1 
RT, XX , 2 
PR, 17 
RT , X X , 1 
EN 


Output is* 

A 1 000001 
A 1 000002 
A 1 000003 
17 000001 
A 1 000004 
A 1 000005 
A 1 000006 
17 000002 
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RA Request Sector Address, The word returned from the 

controller containing the logical address of the 
sector currently passing under the heads of the 
specified unit is placed in the read buffer. 

Follow this command with a DR,0 to display the 
value returned. 

RC Recalibrate. A recalibrate command is issued to 

the disc. 

Read Data. Transfer the number of words indicated 
from the disc to the read buffer. Default case is 
128 words. (XXXX = word count.) Maximum word 
count is 1024 if 32K-bytes of memory or 8192 if 
64K-bytes. End of cylinder may occur if data to be 
read is not on the same cylinder and the file mask 
is not set appropriately (i.e., either in cylinder 
mode and/or incremental or decremental seek mode) . 

Read Full Sector (similar to RD) . A read full sec- 
tor command is performed for XXXX words. Default 
word count is 138. Maximum word count is 966 
(seven full sectors) if 32K-bytes of memory or 8192 
(59 full sectors) if 64K-bytes. 

Run instructions . Will cause the set of previously 
entered instructions to run again. This 
instruction is undefined if the program has been 
destroyed (any of test sections 1 through 5 have 
r un ) , 

RL Reload. Issues a seek to the controller with the 

same cylinder, head, and sector as currently 
assigned in the OPDSN program. 

RN Restore the cylinder, head, and sector which was 

stored by the last SN instruction executed in the 
OPDSN program (i.e., R2 will restore the value 
saved by S2). (N = 0, 1, or 2) 

ROC, [XXXX] C,[+CCJ C , A 3 ] ] 

D 

Read with Offset. Issues a read with offset 
command to the disc. XXXX = word count (default = 
128) . CC = cylinder offset (must have sign) . A * 
Advance clock. D * Delay clock. Default is no 
offsets. End of cylinder may occur. 

RS Random Seek. This instruction will cause a random 

cyl inder-head-sector combination to be generated 
and will then seek to the random location. Switch 
Register bit 6 is used to randomly select from the 
cylinder table. Head is selected from the head 
table. 


RD [,XXXX] 


RF [,XXXX] 


RI 
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RT,LL,X Return. Return to the indicated label (LL = label) 

in the OPDSN program X number of times. The label 
returned to must precede the RT instruction in the 
OPDSN program. The initial value of X is reset if 
the OPDSN program is restarted. (X = 32767 
maximum. ) 

RW Read without verify. Similar to RD but the 

previous sector is not verified by the disc 
controller. 

SB,LL Subroutine LL. This instruction defines the 

beginning of a subroutine? it must occur in the 
program before the LV,LL instruction occurs (LV,LL 
is leave subroutine LL). The instruction immedi- 
ately following the subroutine call instruction is 
the next instruction executed when leaving a 
subroutine. Each subroutine must have a unique 
label. Any valid label rnay be used as a subroutine 
name. Subroutines may be nested to any level, but 
they must not be recursive. An SB,LL instruction 
can only be executed as a result of a CA,LL 
instruction. Therefore a3 1 subroutines must be 
preceded by a command which transfers control to 
some other OPDSN instruction. Ibis may be done 
with a GO, XX or LV,XX instruction. (Also see LV,LL 
and CA,LL i nstruct ions . ) 

SC [ , [ TTTTTTTTTTTTTTTT 3 C , TTTT TTTTTTTTTTT1 3 3 

Status Check. The last hardware status ( STATUS- 1 
and STATUS-2) is checked bit by bit against the 
expected status represented by the two sixteen bit 
strings (TTTTTTTTTTTTTTTT). Each bit may be a 0, 1 
or X (for don't care). If they do not compare, an 
error message is reported. Default status is 
0000000000000 VVV (YYY = unit number) and 
0AAAAAA000X00000. ( AAA AAA = drive type). Any 

status may be specified but the unit number and 
drive type will be "inclusive or'ed". This 
instruction does not change the current operation 
message output by the diagnostic on an error. 

SD,X Select Drive. Drive X becomes current unit to 

which OPDSN instructions will be issued. 

SK C , ( CCC ] [ , [ H 3 [ , SS 3 3 3 

Seek. Seeks to cylinder, head, and sector 
specified in SK instruction. Default condition is 
zero. (CC = cylinder, H = Head, SS = sector) 
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SM [,XXXXXXJ 


SN 

ST 


Set File Mask. Controller file mask (Appendix C) 
is set to XXXXXX (octal). Default case is 000002 
(octal) which equals cylinder mode. 

Saves the current cylinder, head, and sector for 
use at a later time. The value saved may be 
recalled with a RN instruction. (N =0, l, or 2) 

Status. Issues a status command to controller to 
obtain new values for SfTATUS- 1 and STATUS-2 words. 


TB [,N] 


TC,CCC,X,Y 


Transfer Bluffer. Transfer first N words of read 
buffer to write buffer. ( n = number of words 

transferred.) 0 < N <_ 1024 for 32K-bytes of mem- 
ory and 8192 for '64K-bytes 

Transfer cylinder CCC from surface X to surface Y. 
This instruction can only be used on a 7905 or 
7906 Drive and is intended primarily for transfer- 
ring those cylinders which were not transferred 
correctly with the TS instruction. (Refer to the 
TS instruction for further information.) 


Note: The PROTECT switch must be ON for surface X and OFF for surface 

Y, and the drive FORMAT switch must be ON. 


TS f X, Y Transfer surface X to surface Y. This instruction 

can only be used on a 7905 or 7906 and is intended 
primarily for saving and restoring the fixed sur- 
face. The information transferred from surface X 
to surface Y includes the 128 data words in each 
sector and the sync, cylinder, head/sector, CRC, 
and six ECC words. (This is accomplished by using 
the Read Full Sector and Write Full Sector instruc- 
tions.) As a result, an attempt to read or verify 
surface Y will result in a "head/sector compare” 
error unless the head address written in the sector 
preamble is equal to the physical head being 
addressed. 


Before transferring surfaces, check that the drive 
can read from the fixed surface by performing the 
read operation in example 4 of the Helpful Hints 
portion of this manual. 


Mote: Set the PROTECT switch to ON for surface X and OFF for surface 
Y and the drive FORMAT switch to ON when executing the TS,X,Y 
i instruction. 

Note* A CP,X,Y instruction should be used following a TS,X,Y 

instruction to check that the information was transferred 
correctly. The PROTECT switch must be OFF during the CP 
instruction. Any cylinders for which errors occur during a CP 
command should be retransferred using the TC,CCC,X,Y 
instruction? the CP instruction should then be executed again. 
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Note: Example 6 in the Helpful Hints portion of this manual is an 

equivalent OPDSN program for the TS,X,Y instruction. 


Mote: The removable cartridge contains surfaces 0 and 1. The fixed 

surface is surface 2 on 7905 and, 2 and 3 on 7906 . To save the 
fixed surface, set the LOWER PROTECT switch to ON and enter the 
following OPDSN program: 


TS , X , Y 


EN 


X = fixed surface 
Y = removable surface 


To check the transfer, clear the LOWER PROTECT switch and enter 
the following OPDSN program: 


CP , X,Y 


EN 


X = fixed surface 
Y = removable surface 


To restore the fixed surface, set the UPPER PROTECT switch and 
enter the following OPDSN program: 


TS , Y , X 


EN 


Y = removable surface 
X = fixed surface 


To check the information restored, clear the UPPER PROTECT 
switch and enter the following OPDSN program: 


CP, Y,X 
EN 


Y * removable surface 
X * fixed surface 


If any errors occur during the CP instruction refer to the 
TC instruction. 

VD Verify Defective. Check last status received from 

controller. Output message HI41 CYL = XXXX, HD = 
XX, UNIT =XX DEFECTIVE if defective bit of STATUS- I 
word is set. 


VFC,XXXXJ Verify. A verify command is issued for XXXX 

sectors. Default is one sector. 

VH Verify Heads. Verifies all heads in head table. 

Same as VN, but for each head in the head table. 

VN Verify surface N (N = head 0-2 for 7905, 0-3 for 

7906, 0-4 for 7920, and 0-8 for 7925). This 
instruction is the same as: 


LB, AA 
IS ,N 
VF , SS 

SS * 

48 for 7905/7906/7920 and 
64 for 7925 

RT,AA,ZZ 

ZZ * 

410 for 7905/7906 and 
822 for 7920/7925 
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VP 


VS 


WD C.XXXX3 


WF U XXXX I 


Verify Protected. Check last status received 
from controller. Output message HI 4 1 CVL = XXXX, 
HD = XX, UNIT = XX PROTECTED, if protected bit of 
STATUS-! word is set. 

Verify Spare. Check last status received from 
controller. Output message H141 CVL = XXXX, HD = 
XX, UNIT = XX SPARE if spare bit of STATUS-1 word 
is set. 

Write Data. Transfer indicated number of words 
from write buffer to disc. Default case is 128 
words. (XXXX = word count.) End of cylinder may 
occur as in RD instruction. 

Write Full Sector (similar to WD). A write full 
sector command is performed for XXXX words. 
Default word count is 138. 


3-8. HELPFUL HINTS 

The examples described in this paragraph are as follows* 

* Loop on step /test section. 

* Test specific cylinders, long seeks, and heads. 

* Test read operation. 

* Test for properly formatted disc. 

* Determine spare, protected, or defective tracks. 

* Disc copy program. 

* Possible causes of miscellaneous problems. 

* Flag a track defective. 

* Generate a correctable data error. 


Example 1. Loop on step/test section. 

This example may be used to verify that a particular step or section 
is executing, or to execute a particular test or series of tests. 

To loop on a particular step during diagnostic execution, set Switch 
Register bit 3 and the diagnostic will transfer control to the OPDSN 
section of the diagnostic. 
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Enter the OPDSN instruction LS t N (where N = the step to be looped on) 
and press RETURN* The diagnostic begins execution at START (step 0) 
of the diagnostic and will loop on step N when executed, at which time 
Switch Register bit 13 is set. 

For example, to test the ability of the controller to correct 
correctable data errors, type L5,4l when in OPESN, since step 41 of 
the diagnostic performs this test. 

To loop on a particular test section (one test or a series of tests 
may be in more than one step), type LS,N (N = the number of any step 
in that section) when in OPDSN, which will cause the diagnostic to 
loop on step N when executed. When the diagnostic sets Switch 
Register bit 13 indicating the diagnostic is looping, set Switch 
Register bit 7 and clear bit 13, which will cause the diagnostic to 
loop on the desired test section. 

If N is not a valid step number, the diagnostic will not loop on any 
diagnostic step and execution will continue as usual. The following 
OPDSN program illustrates this* 

FH Format all heads in the head table for the 

current unit. 

LS, 100 Loop on step 100. 


The diagnostic begins execution when all the specified heads have been 
formatted. Since step 100 does not exist, the diagnostic will begin 
execution as per the switch register options. 

This approach may be used for any OPDSN program; it is not limited to 
format instructions. 


Example 2. Test specific cylinders, long seeks, and heads. 

To test a particular band of cylinders (e.g., cylinders 300 thru 410) 
place the following cylinders in the cylinder table via the bit 2 
dialogue, set Switch Register bit 6 (only those cylinders in the 
cylinder table are referenced), and execute the diagnostic* 300, 310, 
320, 330, 340, 350, 360, 370, 380, 390, 400, 410. 

To test the execution of long seeks on a 7905, place the following 
cylinders in the cylinder table via the bit 2 dialogue, set Switch 
Register bit 6, and execute the diagnostic* 0, 410, 0, 410, 0, 410, 0, 
410, 0, 410, 0, 410 

Note i Use 822 in place of 410, if using a 7920. 

To test one particular head, place only that head number in the head 
table via the bit 2 dialogue. 
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Note* An RS command in an OPDSN program or any random seek will only 
access the heads that are in the head table for the desired 
drives . 


Example 3. Test for properly formatted disc. 

To determine if a disc is formatted correctly check the preamble, CRC, 
and ECC words of a sector by executing the following OPDSN program* 

Note* A read full sector (RF) instruction reads 138 words which 
consist of the following* 

word 0 = sync word = 100376 

word 1 = address of cylinder 

word 2 = bit 15 « set if track is spare 

bit 14 = set if track is protected 

bit 13 * set if track is defective 

bits 12-8 = address of head 
bits 7-0 = address of sector 

words 3-130 = 128 data words 

word 131 » Cyclic Redundancy Code (CRC) 

words 132-137 = Error Correction Code (ECC) 


SK , CC, HH, SS 
RF 

DR, 0,2 
DR, 131 ,137 
DR, 3, 130 
DR, 3, 7 
EN 


Seek to cylinder CC, head HH, and sector SS . 
Read one full sector of 138 words. 

Output sync, cylinder, and head/sector words. 
Output CRC and ECC words. 

Output entire data sector from 3 to 130. 
Output first five words of data sector. 

End of OPDSN program. 


Note* A read (RD) instruction reads in 128 words (0 thru 127), which 
does not include the sync, cylinder, head/sector, CRC or ECC 
words . 
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SK,CC,HH,SS 

RD 

DR, 0/127 
EN 

Example 4. Test 


Seek to cylinder CC, head HH, and sector SS . 
Read one sector of 128 words. 

Output entire sector from 0 to 127. 

End of OPDSN program, 
read operation. 


To determine if a problem is due to read or write problems, or 
possibly to a data cable (defective or not connected), execute the 
following OPDSN program where cylinders 10 and 20 are not spare, 
protected, or defective* 


SK , 10 , 2 

Seek to cylinder 10, head 2. 


RF 

Read a full sector (i.e., 138 words). 


DR, 0,2 

Display the sync, cylinder, and head/sector 
just read. 

words 

SK , 2 0 , 2 

Seek to cylinder 20, head 2. 


RF 

Read a full sector. 


DR, 0,2 

Display the sync, cylinder, and head/sector 
just read. 

words 

EN 

End of OPDSN program. 



The output should be as follows* 

0000: 100376 000012 001000 

0000: 100376 000024 001000 


If the words output from each track do not agree with those shown 
above, errors may be due to a defective data cable or the data cable 
is not connected. 


Example 5. Determine spare, protected, or defective tracks. 

To determine which tracks are spare, protected, or defective, enter 
the following OPDSN program* 
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LB, A0 

Define label A0 . 

IS 

Seek to the next cylinder on head zero. 

L B , A 1 

Def ine labe 1 A 1 . 

RI- 

Seek to, the cylinder, head, and sector currently 
used by the diagnostic. 

VE 

Verify one sector to obtain S, P, D information 
from the track. 

VD 

Check if the track is defective. 

VF 

VS 

Check if the track is spare. 

VF 

VP 

Check if the track is protected. 

CH, 1 

Change the head addressed by the diagnostic by 
one modulo number of heads on the drive. 

RT , Al , 2 

Return to label Al, two times, to check all three 
heads in 7905. (Replace 2 by 3 for 7906, 4 for 
7920, and 8 for 7925.) 

RT , AO , 410 

Return to label A0, 410 times, to check all 411 
cylinders. (Replace 410 by 822 for a 7920/7925.) 

EN 

End of OPDSN program. 


Example 6, Disc copy program. 

Note: Before performing this procedure, check that the drive can 

read from the fixed surface by performing the read operation 
in example 4 of the Helpful Hints portion of this manual. 

The following two programs are included to illustrate the use of 
several of the new OPDSN instructions and to show the equivalent OPDSN 
programs for the IS , X, V and CP,X,Y OPDSN instructions. 

The following* two programs can be used to copy or restore the data on 
a fixed platter on a 7905 to or from a removable cartridge, and to 
check that the data is transferred correctly. 

The first program makes an exact copy of one surface to another, thus 
the address portion of the copied version is the same as it was on the 
original surface. Due to this, a regular read rather than a read full 
sector will result in a head sector compare error. In performing the 
copy, each sector to be copied is read twice to ensure the data is 
read correctly. The data is then written to the other surface and 
read back to ensure the data has been transferred correctly. Proceed 
as follows* 


Note* This program will cause several error messages to be output if 
the surface being copied or the surface being copied to has 
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tracks which cannot be written on or read from cons istently . 
(Some other method of copying the surface should be used.) 


a. Protect the surface to be copied from by setting the proper 
UPPER/LOWER DISC PROTECT switch. 

b. The following table applies to the following two OPDSN programs 
and are not the values used in the TS or CP OPDSN instructions. 
Insert the following values into the OPDSN program wherever the 
letters W, Y, or Z occur* 



Note* Head 2 is for the fixed platter* 

Special attention should be given to those tracks on which errors 
occur to ensure they are copied correctly. 


c. The OPDSN program is as follows* 

GO,BB Skip over subroutines to label BB. 

SB, AI Start of subroutine Al. 

RL Issue a seek to the cylinder, head, and sector 

currently used by the diagnostic. 

SC, XXXI 111 1 00000000, 000000000XX00000 

Check for drive attention due to seek completion 
and disregard the format or protect switches. 

RF,828 Perform a read full sector (for six sectors). 

SC , 0000000000000000, 000000000XX00000 

Check status for NORMAL COMPLEX. Disregard 
format or protect switches. 

LV,A1 Leave subroutine Al . 
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SB,A0 Start of subroutine A0. 

LB, A3 Define label A3, 

CA , A 1 Call subroutine A1 to perform a seek and a read 

full sector for six sectors. 


TB , 8 28 


CA , A 1 
CH , W 


RL 

SM 


CB, 828 ,3 


WF ,828 


Transfer the six sectors read from the read 
buffer to the write buffer. 

Call subroutine Al to perform a seek and a read 
full sector for six sectors. 

Change the head currently used by the diagnostic 
by W modulo number of heads on the drive. (Refer 
to the table in step b for the value of W.) 

Issue a seek to the cylinder, head, and sector 
currently used by the diagnostic. 

Issue a set file mask command to the drive. This 
is to return a STATUS- 1 word equal to zero which 
is what is expected by the following CB 
i ns true t ion. 

Compare 828 words of the read and write buffers 
to check that they are equal. Output up to the 
first three words in error. 

Write the six full sectors read from the initial 
surface onto the second surface. 


SC, 0000000000000000, 000000000 XX00000 


CA , A 1 


RL 

SM 


CB ,8 28',3 


Check for NORMAL STATUS returned and disregard 
the protect and format switches. 

Call subroutine Al to perform a seek and a read 
full sector of six sectors. 

Perform a seek to the cylinder, head, and sector 
currently used by the diagnostic. 

Issue a set file mask command to the drive. This 
is to return a STATUS-1 word equal to zero which 
is what is expected by the following CB 
ins truct ion . 

Compare the 828 words of the read and write 
buffers to check that they are equal. Output up 
to the first three words in error. 


CS ,6 


Change the sector currently used by the 
diagnostic by six. 


3-25 



Operating Procedure 


CH f Y 


RT,A3, 7 
LV,A0 


Change the head currently used by the diagnostic 
by V modulo number of heads on the drive. (Refer 
to the table in step b for the value of Y.) 


Return to label A3 seven times so that all eight 
groups of six sectors each are copied. 

Leave subroutine A0. 


LB,BB Define label BB. 

IS„Z Issue incremental seek to head Z. (Refer to the 

table in step b for the value of Z. ) 


SC, XXXI 1 1.1 100000000,0000000001X00000 


Check status for drive attention due to previous 
seek and the appropriate DISC PROTECT switch on. 

CA,A0 Call subroutine A0. 

RT,BB,410 Return to label BB 410 times. 

EN End of OPDSN program. 


The following 
against each 
surfaces of a 

program should now be run to compare the two surfaces 
other. The second program which compares the two 
7905 is as follows* 

Note* The drive protect switches must not be on. 

GO, BB 


Skip over subroutine to label BB. 

S B , A 0 


Start of subroutine A0. 

LB , AA 


Define label AA . 

RL 


Seek to the cylinder, head, and sector currently 
used by the diagnostic. 

RF , 8 28 


Perform a read full sector for six sectors. 

TB , 8 28 


Transfer the six full sectors read, to the write 
buffer . 

CH , W 


Change the head currently used by the diagnostic 
by W modulo number of heads on the drive. (Refer 
to the table in step b for the value of W.) 

RL 


Seek to the cylinder, head, and sector currently 
used by the diagnostic. 
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RF , 8 28 


Perform a read full sector for six sectors from 
the other surface. 


CB, 828,3 


CS, 6 


CH , V 


RT, AA, 7 


LV,A0 
LB, BB 


Compare the two sets of six sectors read. Output 
up to the first three errors. 

Change the sector currently used by the 
diagnostic by 6 modulo number of sector per 
track . 

Change the head used by the diagnostic by V 
modulo number of heads on the drive. This 
restores the original head number. (Refer to the 
table in step b for the value of V.) 

Return to label AA seven times. 

Leave subroutine A0. 

Define label BB . 


I S , , Z 


CA, A0 


Perform a seek to head Z and seek to the next 
cylinder each time it is executed. (Refer to the 
table in step b for the value of Z. ) 

Call s u br ou tine A0 . 


RT ,DB, 41 0 Return to label BB 410 times. 

EN End of OPDSN program. 


Example 7. Possible causes of miscellaneous problems. 

Almost any error which occurs can be caused 
thus the ECC board should be checked. 

PROBLEM 


Intermittant data errors 
traceable to controller. 

Linear motor loads all the way 
to crash stops, then retracts. 


Spindle motor does not turn. 


by defective firmware, 

POSSIBLE CAUSE 

Check operation of fan on left 
s ide . 

Missing AGC on Track Follower. 

Absent Servo Code on platter. 

Servo head disconnected from Track 
Follower PCA. 

Disc Pack Jamming Spindle. 

IL Fault. 
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Spindle does not rotate at 
correct speed. 

Heads load and then retract. 


Brush motor inoperative. 


Spindle motor spinning, heads 
do not load and there is no 
Drive Fault. 


Heads do not load plus a T.O. 
Fa ul t • 


C.B. Fault 


Receiver warped. 

Disconnected Display PCA. 

Door not tightly closed. 

Pack-in-pla ce ( cartrict? e-in-p Jace ) 
switch faulty. 

Control PCA faulty. 

Power board. 

Track Follower board. 

DOOR UNLOCKED light burned out. 

Spindle motor defective if heads 
will not load below 110V ac. 

26V ac fuse blown on Power board. 

Brush Back switch misad justed. 

Power board. 

Brush motor not plugged into mother 
board . 

Brush cycle did not occur. 

Defective Spindle Encoder board. 

Power board. 

Faulty Spindle motor. 

Open velocity (tachO coil. 

Disconnected tach coil. 

Carriage solenoid misadjusted or 
faulty. 

Control board 

Servo board 

Defective CB photoswitch. 

Switch tab bent or missing on 
linear rotor. 
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T.O. Drive Fault Coil band to barrier block loose. 

Sticky carriage solenoid. 

Abraded coil band. 

Faulty tach coil. 

Power board. 

Control board. 

Servo board. 

WAC Fault Control board. 

Open head winding. 

Preamp board. 

Data cable open or disconnected. 
Mother board. 

IL Drive Fault Faulty fuse cap/holder. 

Blown fuse. 

Any regulated supply shorted. 

Spindle Encoder board connector 
1 oose . 

Any board not fully inserted. 

26V ac fuse on Power board blown. 

Defective Heat Sense switch on 
Power board. 

B]ower lailure. 

AGC Drive Fault Intermittent tach coil. 

Coil band shorting to centerplate. 

“Crap in Gap" on linear motor (bits 
of steel captured by magnet scraping 
thru the epoxy cover on linear motor 
coil . 

Track Follower board. 

Servo board. 
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Intermittant IL Fault 


Loose connections on filter 
capacitors . 

Faulty fuse holder/cap. 
Loose lower disc. 


Int ermittant seek errors and 
WA$ Faults accompanied by erratic 
seek times using the DSU. 

5 volt supply crowbarred (blower 
motor runs, but no Unit Select 
light). 


Brush motor runs continuously. 


-24V fuse blown (located on 
Power board). 

Intermittant head unloading. 


Linear motor will not emergency 
retract. 

Linear motor crashes to stops 
and then retracts. 


Linear motor oscillates. 


Defective mother board. 

5V shorted on card cage board. 

Connector on display board missing 
or misaligned. 

Misad Justed Brush Back micros witch. 
Power board. 

Jammed pa ck p revents spindle from 
turning ( 5 P D must be false or Brush 
motor will continue to run). 

Blown capacitor (o.8 microfarads) on 
Preamp PCA (located bottom center). 

Power board. 

Spindle Encoder PCA. 

Intermittant microswitches. 

Low ac line voltage. 

Power board. 

Shorted velocity transducer. 

Faulty Servo PCA. 

Faulty coil capacitor (replace 
a ctua tor ) . 

Faulty Servo code. 

Abraded coil band. 

Tach coil . 

Tach Rod. 
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Incompatabi li ty of two drives. Sector transducer on one drive mis- 

aligned past 4 microseconds. 

Do not receive "Drive Ready". Encoder board. 

IC on time delay board. 

Linear motor tries to retract Velocity transducer unplugged or 

instead of load. open. 

Intermittant SPU. Adjust "door closed" switch. 

Check cartridge-in-place (pack-in- 
place) micros wi tch . 

Intermittant "carriage back" switch. 
Defective spindle motor. 

AC power lost. Check line filter. 

Excessive errors on one head. Replace head. 

Bad sur fa ce . 

Does not format. Device controller. 

Microprocessor. 

Mother board. 

Drive faults after or during Seek time as set on Servo board may 

a seek to the last cylinder. be too low (fast). 

Servo board may be miscounting. 

Track follower may be faulty (not 
sending correct signals to Servo 
board ) . 

The Servo formatted information may 
be defective. 

Uneven and/or hesitation of Track Follower board, 

needle swing during head 
al ignment. 

Read with offset errors. Track Follower board. 

Heads vibrate and lose "Drive Track Follower board. 

Ready". 

Seek Check errors. I/O Sector board. 

Could not align sector I/O Sector board, 

transducer • 
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Example 8. Flag a track defective. 

To flag track Cl, Hi defective and spare it to C2,H2, execute the 
following OPDSN program: 

SK ,C1 , Hi Cl = cylinder. Hi = head. 

AR,C2,H2 

ID, , D Flag track Cl, Hi defective and spare to 

C2,H2. 

SK,C2,H2 
AR ,C1 , Hi 

ID , , S Flag track C2,H2 spare for Cl, HI. 

EN 

Example 9. Generate a correctable data error. 

To generate a correctable data error, execute the following 
OPDSN program: 

SK, Cl, HI, SI 
RF 

TB , 138 

RL 
RD 

DW,NN 

CW, NN, XX XXX X 
RL 
WF 

TB, 128 
RL 
RD 

CB, 128,3 


Cl = cylinder. Hi « head, SI = sector. 

Read full sector. 

Transfer 138 words of read buffer to 
write buffer. 

Reseek to same location. 

Read data portion of sector. 

Print value of word NN (3 < NN < 130) . 

Change word NN of sector to XXXXXX. 

Reseek to same location. 

Write a full sector with one word changed. 
Transfer data portion to write buffer. 
Reseek to same location. 

Read modified sector. 

Compare buffers and verify that the data 
was corrected. 


EN 

Note: NN is a full sector number and will be three (3) more than the 

value reported in the message from the CB instruction. 
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AND INFORMATION MESSAGES ! 

I A 


Table A- 1 . Halt Code Summary 


HALT 
(octal ) 

MEANING 

102001 

Error halt; indicates non-information type 
messages . 

102002 

Operating instruction or comment; indicates 
operator action is required. 

102004 

Orderly halt at end of current step. 

102005 

(See information message HI.) Push RUN to restart 
diagnostic. 

102006 

Push RUN to restart diagnostic. (See messages E50 
and E103. ) 

1 020 1 X 

Halt between sections (X = section number). 

102073 

Control halt. Illegal select code during 
configuration of the diagnostic. 

102074 

Control halt. Halt at end of diagnostic 
configuration . 

1060 XX 

Control halt. Trap cell interrupt. P-register = 
memory address when interrupted, XX = trap cell 
location. (Refer to paragraph 2-3, step b for 
further details . ) 


Note* For any other halts, refer to the Diagnostic 

Configurator Reference Manual , part no. 02100-90157 
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A-1 . ERROR AND INFORMATION MESSAGES 


MESSAGE COMMENT 

H0 79XX/1 3037 DISC Preamble. Output at beginning of 

MEMORY DIAGNOSTIC diagnostic. 

HI UNIT X REMOVED Unit has been removed from the unit 

FROM UNIT TABLE table. Removal results from number of 

errors/pass exceeding the number spec- 
ified (see Appendix B , (?)ERRS). Halt 
occurs if unit table is empty. 

(Default * 40) 

E2 CLF or SFS FAILED Test the ability of the computer to 

clear the controller channel flag on the 
interface card. Error occurred in the 
START area of the diagnostic'. Possible 
causes of error are the interface card or 
the computer. Ensure the proper select 
code was used during configuration. 

H3 READ FULL SECTOR Current operation is read full sector. 

IN STEP X 

H4 CLEAR IN STEP X Current operation is clear. 

E5 SFS FAILED WITH Test the ability to set controller 

FLAG SET channel flag on interface card. Possible 

causes of error are the interface card or 
the computer. 

E6 NO INTERRUPT No interrupt occurred on controller 

channel when expected. Test interrupt 
capability. Check the interface card or 
the computer. Ensure that all I/O slots, 
in the computer, of lower select code 
number than the controller interface have 
something in them. 

E7 WRONG RETURN Return address stored when interrupt 

ADDRESS occurred is incorrect. Possible causes 

of error are the interface card or the 
computer . 

E10 NO FLAG FOLLOWING The flag on the controller interface card, 
OPERATION which indicates the completion of a 

command, was not set within 100 milli- 
seconds. Possible causes of error are* 

a. Device Controller board 

b. Microprocessor 
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El 2 


E13 


Note 


c. Error Correction Code 

d. I/O Sector board 

e. Drive Control board 

f. Track Follower board 

LATE FLAG The device flag on the controller inter- 

face card, which acknowledges some input 
from the computer, was not set until after 
100 mi 11 is econds , or the computer was 
expecting a non-DMA transfer from the 
controller (i.e. ! , status words, syndrome) 
in response to a command and the flag was 
set after 100 mi 11 is econds . This may 
occur between any of the words transferred 
in a multi-word, non-DMA transfer. (The 
flag was eventually set.) Possible 
causes of error are* 

a. Microprocessor 

b. Device Controller board 

c. Drive Control board 

d. I/O Sector board 

e. Track Follower board 

NO FLAG CGEITING Same as Ell, except the flag was never 
STATUS) set and the two words to be returned were 

the two status words. Possible causes of 
error are* 

a. Device Controller board 

b. Microprocessor 

c. I/O Sector board 

d. Drive Control board 

e. Error Correction Code (ECC) board 

When the operation complete flag occurred 
(i.e., the flag was set) on the control- 
ler interface card, the DMA transfer was 
not complete. 

This message is output only if a data transfer error does 
not occur in the last sector transferred. 

Possible causes of error are: 


XXXX WORDS 
TRANSFERRED 
YYYY EXPECTED 
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a. If termination status is “NORMAL 
COMPLETE 1 ' or "OVERRUN", check the 
DCPC in the computer or the interface. 

b. Drive Control board 

c. Preamp 

d. I/O Sector board 

E14 NO FLAG (USING A transfer using DMA was in progress, 

DMA) and a controller channel flag on the 

interface indicating operation complete 
did not occur. Possible causes of error 
are * 

a. Device Controller board 

b. Microprocessor 

c. I/O Sector board 

d. Track Follower board 

e. Drive Control board 

HI5 ADDRESS RECORD Current operation is address record. 

IN STEP X Check the microprocessor if errors occur. 

H16 OVERFLOW Work space for OPDSN program is full 

(36000-36477 (octal) if 32K-bytes, 36000- 
37777 (octal) if less than 64K-bytes, and 
34000-35777 (octal) if 6 4 K- bytes) . 


H 1 7 DUPLICATE LABEL 

H20 UNDEFINED 

INSTRUCTION 

E21 INVALID UNIT 
H22 VERIFY IN STEP X 


Last label input in OPDSN program 
with an LB,LL or SB,LL has been 
previously defined. 

Last instruction input in OPDSN 
program is not valid. 

An invalid unit has raised attention 
following overlapping seeks. See 
message H33 for the order of attentions. 
Error occurred in test section 5, step 
85. Possible cause of error is the 
system cable connections. 

Current operation is verify. Check the 
following if errors occurs 

a. Preamp 

b. Drive Control board 
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c. Heads 

d. Data cable attachment 

H2.3 XXXXXX ERRORS/PASS XXXXXX = unit removal threshold? the 
ALLOWED number of errors allowed per pass on a 

given unit before it is removed from the 
unit table. 

H24 CYLINDER TABLE FOR Contents of cylinder table. Only these 
DRIVE TYPE 79XX cylinders will be read or written to if 


XXX, 

XXX, 

XXX, 

XXX, 

Switch Register 

bit 6 is set during test 

XXX, 

XXX, 

XXX, 

XXX, 

sections 1 thru 

5. 

XXX, 

XXX, 

XXX, 

XXX 




H 25 WISH TO CHANGE? Operator types* (Y)ES or (N)0 f or (E)XIT, 

or any of the valid inputs for the bit 2 
dialogue , (U)NIT, (?>ERRS f (H)EAD f 
(O)UTPUT, (P)ATT, (S)OFT, (C)YL, (M)CPU f 
except when the diagnostic gives the 
default unit table entry and asks if you 
wish to change. 

H26 ENTER CYLINDERS Operator types the desired cylinders, 

SEPARATED BY COMMAS all on one line. (Refer to Appendix B, 

(C)YL.) 

H27 PATTERN TABLE Contents of pattern table. (XXXXXX = 

XXXXXX XXXXXX pattern in octal.) (See Appendix B, 

XXXXXX XXXXXX ( P ) ATT . ) 

XXXXXX XXXXXX 
XXXXXX XXXXXX 
XXXXXX XXXXXX 

H30 ENTER PATTERNS Operator types desired patterns, all on 

SEPARATED BY COMMAS one line. (Refer to Appendix B, ( P) ATT. ) 

H3I INPUT ERROR Bad input from console device. 

H32 ENTER ERRORS/PASS Operator types number of errors/pass 

allowed on a unit before removing it 
from the unit table. (Refer to Appendix 
B, ( ? ) ERRS ) . 

XXXXXX = STATUS- 1 word following each 
seek complete. YYYYYY = STATUS-2 
word for the unit determined from 
STATUS- 1 word. All values are octal. 

Any error terminates process. Refer 
to Appendix C for status definitions. 

H34 ENTER UNIT NUMBERS Operator types desired unit number (s), 

(0-79 SEPARATED BY all on one line, which are placed in the 
COMMAS unit table. 


H 33 SEEK-STATUS 

XXXXXX YYYYYY 
XXXXXX YYYYYY 

• • 

• • 

• • 
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H35 

STATUS IN STEP X 

Current 

H36 

INITIALIZE DATA 

Current 


IN SI EP X 

(write 



errors 


operation is status command. 

operation is initialize data 
address). Check the following if 
occur * 


a. Drive FORMAT switch not ON. 

b. Bad spot on media. 

c. Device Controller board 

d. Microprocessor 

e. Preamp 

f. Drive Control board 

g. Data cable 


H37 

UNIT TABLE: XX 
DRIVE(S) A, B. . . 

Contents of unit table. XX = number 
drives. A,B... = units selected. 

of 

H40 

SET READ ONLY 
SWITCH, PUSH RUN 

Operator sets READ ONLY switch on front 
panel of drive. 

H41 

CLEAR READ ONLY 
SWITCH, PUSH RUN 

Operator clears READ ONLY switch on 
front panel of drive. 


H42 

UNIT X ATTENTION 
SET-STATUS IS \ 
AND 2 

Interrupt was unexpected; came from 
X. Y = STATUS-1 word. Z = STATUS-2 
Check the following if errors occur* 

unit 

word. 


a. Device Controller board 


b. Microprocessor 

E43 DMA MISSING Possible causes of errors are: 

a. DMA/DC PC missing 

b. Interface 

H44 SEEK IN STEP X Current operation is seek. Check the 

following if errors occur* 

a. Device Controller board 

b. Microprocessor 

c. Check ribbon cable connection if seek 
executes with the DSU, but not with 
the computer. 
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H45 WRITE IN STEP X Current operation is write. Check the 

following if errors occur* 

a. Device Controller board 

b. Microprocessor 

H46 READ IN STEP X Current operation is read. Check the 

following if errors occur* 

a. Device Controller board 

b. ECC board 

The data returned on a read operation 
did not match the expected data. This 
message is typed only for the first three 
erroneous words in the buffer (except 
for CB in test section 6). Check the 
Device Controller board for possible 
cause of error. 

This message is output whenever the 
selected unit X is not ready. Any 
other units found to be ready are 
shown. Halt occurs if on first pass. 
Error occurs in START area. Possible 
causes of error are* 

a. Desired unit is not connected. 

b. Device Controller board 

c. I/O Sector board 

d. Microprocessor 

CCCC = cylinder, HH = head, and SS ■ 
sector. Word count equals number of 
sectors to be verified if current opera- 
tion was a verify, otherwise it equals 
the number of words to be transferred 
between the controller and the computer. 
The old cylinder is the previous cylin- 
der to which a seek was issued. 


E52 BUFFER CHECKSUM The checksum should be zero and the 

XXXXXX CVL XXXXXX address in parenthesis (decimal) should 
( YYYY )HD/SXXXXXX match the one typed out in the next 

(H=YY S=YY) H5I message. (XXXXXX = values in octal). 

Either the wrong sector was read or a 
data error occurred. Possible causes of 
error are* 


H51 START CCCC/HH/SS- 
LAST CCCC/HH/SS 
WORD COUNT XXXXX, 
OLD CYL XXXX, 

UNIT XX 


E47 DATA WORD XXXX IS 
YYYYYY SHOULD BE 

zzzzzz 


E50 UNIT X MISSING- 

PRESENT A, B 

(NONE) 
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a. Device Controller board 

b. Microprocessor 

c. Interface 


Note: Each sector is checksummed separately. The entire sector 

sums to zero. This six-digit octal sum is reported as 
the buffer checksum. 

The first two words sum to the cylinder number. This 
six-digit octal sum is reported as the CYL. In addition, 
the four-digit decimal equivalent is shown in parenthesis. 
This equivalent is meaningless if the sum is an invalid 
cylinder number. 

Words two and three sum to the head/sector number. The 
head is in the upper byte of the word and the sector is in 
the lower byte. This six-digit octal sum is reported as 
the HD/S, The decimal equivalent for each is shown in 
parenthesis. These values may also be meaningless for an 
invalid head or an invalid sector. 


H53 AVERAGE SINGLE Time is in milliseconds. Seek covers 

CYLINDER SEEK TIME one cylinder (length = I). (The data is 
X.XX obtained in step 55.) Check the servo 

board or the actuator if the seek time 
exceeds five milliseconds and Switch 
Register bit 6 is clear. 

H54 AVERAGE RANDOM Time is in milliseconds and length is 

SEEK TIME XXXX.X, in cylinders. (The data is obtained in 
LENGTH XXXX.X step 81.) Check the servo board if 

errors occur. 

H55 ENTER INSTRUCTIONS Request for input in operator design 

(CURRENT UNIT = XX) section. XX = the unit to which commands 

will be issued unless changed by a SD 
instru ct ion. 

H56 UNDEFINED LABEL Operator must define label or erase 
XX reference. 

E57 SCREEN TEST ERROR The flag on the disc channel sets when 

some other channel is referenced with 
a STF instruction (i.e., when the flag is 
set on some other channel). Check the 
interface for possible causes of error. 

H60 SET FILE MASK IN Current operation is set file mask. 

STEP X Check the following if errors occur* 
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a. Device Controller board 

b. Microprocessor 

Ho! Used to report current operation 

messages (not seen by operator). 

H62 HEAD TABLE? UNIT N = number of heads selected. A * B . . . 

XX 79XXX ,N = the head(s) which is (are) selected. 

HEAD (S ) A,B... 

E63 NO FLAG The device flag on the controller inter- 

face card which signifies the completion 
of an operation was never set. Possible 
causes of error are* 

a. Microprocessor 

b. Device Controller board 

c. Interface 

d. ECC board 

E64 STATUS IS Z Z Z A status command did not return the 

ZZZZZ ZZZZ ZZZZ / expected status. Values are in ternary 

SHOULD BE Z ZZZZZ (X = don't care). See Appendix C for 
Z Z Z Z Z Z Z Z Z description of status words, 

H65 LONG (SHORT) PASS Short replaces long if SR bits 1 , 5 or 
XXXX, HEAD YYYYYY, o have been set during pass. Multi- 
UNIT X, AAAA ERRORS unit is added if step 85 is run. A 
6BBB SOFT (,MULTI- pass is once through test section 1 to 
UNIT) 5. All values are decimal. AAAA = 

total fatal and soft errors during this 
pass. BBBB = number of soft errors 
during this pass. 

H66 SET FORMAT SWITCH Operator request in test section 1 . 

ON UNIT XX, PUSH Switch is on the front of the drive. 

RUN 

H67 CLEAR FORMAT SWITCH Operator request in test section 1 . 

ON UNIT XX, PUSH Switch is on the front of the drive. 

RUN 

H70 UNLOAD UNIT XX, Operator should place the indicated unit 

PUSH RUN off-line by setting the RUN/STOP switch 

on front of the drive to the STOP 
pos i t ion . 

H71 READ WITH OFFSET Current operation is read with offset. 

=YYYYYY IN STEP X Current offset is YYYYYY in octal. Check 

the following if errors occur* 
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E72 


El 3 


H74 


a. Device Controller board 

b. Track Follower board 

c. Heads 

d. I/O Sector board 

UNIT X NOT READY Not ready bit in status word indicates 

drive is not ready for one of the 
following reasons* 

a. Drive not on line. 

b. Drive not up to speed or heads 
not yet loaded. 

c. Drive fault. 

Error occurs in START area. 


COMMAND REJECTED Disc controller is not busy when it 
= XXXXXX should be. The computer issues a command 

to the controller which sets the controller 
interface flag in the computer acknowledg- 
ing the command. The busy bit on the 
controller interface is set if the command 
is interpreted correctly. This is tested 
with the SFC command. Possible causes of 
error are* 

a. Cables incorrectly connected to 
controller, or the controller crow- 
barred, clear the controller by turn- 
ing the controller power off for a few 
seconds then turning it on again. 

b. Microprocessor 

c. Device Controller board 

d. Interface 


e. ECC board 

SEEK WITHOUT WAIT fhe current error occurred while attempt- 
IN STEP X ing to issue a seek immediately followed 

by a data operation. This results in a 
flag being set on the controller interface, 
indicating the end of operation only after 
the data operation is complete. Check the 
microprocessor if an error occurs. 
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E75 ADDRESS IS XXXXXX This message is output when address 

( V V V V ) AND ZZZZZZ, errors occur. XXXXXX = cylinder address 
OLD CYL = AAAA read from disc (in octal). YYYY = same 

value in decimal. Upper byte of ZZZZZZ 
(which is octal) is the head read from 
the disc. Lower byte of ZZZZZZ is the 
current unit number. AAAA = the cylinder 
at which the heads were at before the seek 
was attempted. Check the servo board or 
track follower for possible cause of error. 

H76 RECALIBRATE IN Current operation is recalibrate. Check 

STEP X the following if errors occur* 

a. Microprocessor 

b. Device Controller board 

E77 NO FLAG GETTING While obtaining the error syndrome with 
SYNDROM F a request syndrome command, the disc 

interface flag failed to set within 400 
mi 11 iseconds . Same as E63, except the 
command was request syndrome. Possible 
causes of error are* 

a. ECC board 

b. Mi croprocessor 

c. I/O Sector board 

HI 00 REQUEST SYNDROME Current operation is request syndrome. 

IN S1EP X Check the ECC board or microprocessor if 

errors occur. 

H 1 0 1 WRITE FULL SECTOR Current operation is write full sector. 

IN STEP X 

E102 NO FLAG GETTING While obtaining the disc address with a 
ADDRESS request disc address command, the disc 

interface flag failed to set within 400 
milliseconds. Same as E63, except command 
was request disc address. Possible causes 
of error are* 

a. Microprocessor 

b. I/O Sector board 

c. Drive Control board 
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El 03 DISC SUBSYSTEM 

DOES NOT RESPOND 
(S.C. = XX) 


HI 04 REQUEST SECTOR 

ADDRESS IN STEP X 


El 05 SECTOR ADDRESS 
ERROR 


HI 06 ENTER HEADS 
SEPARATED BY 
COMMAS 

HI 07 READY UNIT XX 


HI 10 PRESS PRES ETCS), 
PRESS RUN 

HI 14 CYLINDER XXXX 

HEAD YY FLAGGED 
DEFECTIVE 

HI I 5 COLD LOAD READ 
IN STEP X 

HI 16 DATA ERROR 
CORRECTED 


XX = select code diagnostic was configure| 
for. Possible causes of error are* 

a. Controller power off or crowbarred. 

b. Disc select code configured wrong. 

c. Dirty edge connectors. 

d. Device Controller board 

e. Microprocessor 

f. Interface board 

g. Ribbon cable connection between error 
correction board and microprocessor 
board not made. 

h. Cable connection between computer and 
controller not made. 

Current operation is request sector 
address. Check the mi croprocessor if 
errors occur. 

Address returned by request sector addres 
not correct. Error occurred in test 
section 1, step 35. Possible causes of 
error are* 

a. I/O Sector board 

b. Microprocessor 

Operator types heads to be entered into 
the head table, all on one line. 


Load heads on unit XX. Message from 
se ct ion 1 , step 1 5 . 

Message from test section 1, step 20. 


Track has been flagged defective at test 
section I, step 12, or in OPDSN instruc- 
tion FH due to excessive errors. 

Current operation is cold load read. 
Check the ECC board if errors occur. 

This message is output if the words read 
have been corrected by the syndrome. 
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Fill 7 READ WITHOUT 

VERIFY IN STEP X 

El 20 FATAL ERROR 


HI 21 WARNING - FORMAT 
SWITCH OFF 


HI 22 END IN STEP X 


HI 23 REQUEST DISC 

ADDRESS IN STEP X 


El 24 DISC ADDRESS 
ERROR 


Hi 2 5 EXCESSIVE BAD 
TRACKS 


HI 26 SOFT ERRORS WILL 
(NOT) BE PRINTED 


El 27 INTERFACE FIFO 
MALF UNCI ION 


HI 30 NO UNITS IN THE 
UNIT TABLE ARE 
CONNECTED 


Current operation is read without verify. 
Check the microprocessor if errors occur. 

This error is sufficient to crash an 
operating system. 

The controller is more thoroughly 
tested when the FORMAT switch is on. 

Current operation output to controller is 
END/POLL command. 

Current operation is request disc address. 
Check the following if errors occur* 

a. Microprocessor 

b. ECC board 

A seek was issued to the controller. This 
was followed by a request disc address 
command which returned a cylinder, head/ 
sector combination different from that to 
which the seek was issued. Value returned 
is shown as “last" in H5 1 message. Check 
the microprocessor or device controller if 
error occurs . 

There are fewer than 406 useable tracks 
on a surface for a 7905/7906, or 815 
useable tracks for a 7920/7925. A track 
is determined defective and not useable 
if after being initialized, the diagnos- 
tic is not able to verify it in any of 
five attempts. Errors occurred in test 
section 6. Replace the cartridge/pack 
currently being used. 

The (not) part is deleted if soft errors 
are printed during diagnostic execution. 
(Soft errors are always printed during 
OPDSN execution.) 

Error is probably due to a faulty FIFO on 
the interface card. Error occurred in the 
START area. 

Ensure that correct unit number has 
been selected on front of drive. 
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H 1 3 1 WARNING* DRIVE 

TYPE OF UNIT HAS 
CHANGED 


H 1 3 2 TYPE UNITS YOU 
WISH TO CHANGE 
SEPARATED BY 
COMMAS 


It may be necessary to revise drive 
dependent parameters (unit and head 
tables) via bit 2 dialogue. Drive type 
associated with a given unit has changed 
from one drive type to another between 
passes of the diagnostic. This message 
is output if a unit which was off line 
comes on line, or vice versa. 

Operator types the unit number for those 
units whose head table is to be changed. 
(See Appendix B. ) 


HI 33 UNIT XX IS NOT 
CONNECT ID 


Unit XX is in unit table, but is not 
connected to controller. 


HI 34 EXPANDED OUTPUT For expanded output, message H135 is 
(NOT) USED FOR used in addition to E64 message. 

STATUS 


HI 35 S P D TSTAT XXXX 
UNIT / E DRTYPE 
X A P F DF FS SC 
NR B 


Status of last sector transferred to 
controller. S = spare bit indicator on 
sector , 

P = protect bit indicator on sector, 

D = defective bit indicator on sector, 
TSTAT = termination status, 

XXXX = not assigned, 

E = (refer to Appendix C, STATUS-2 word), 
DRTYPE = 000010 for 7905, 000000 for 
7906, 000001 for 7920, and 
000011 for 7925, 

X = not assigned 
A = drive attention, 

P = PROTECT switch on drive set, 

F = FORMAT switch on drive set. 


DF 

= Drive 

Fault, 

FS 

= first 

status to appear after the 


heads 

load. 

SC 

= Seek 

Check , 

NR 

= Drive 

Not Ready, 


B = drive busy. 


HI36 TERMINATION Defines termination status. Refer to 

STATUS WILL (NOT) Appendix C, STATUS-1 word, for definition. 
BE PRINTED Message HI 37 is output when status is 

pr inted. 


HI 37 TERMINATION 

STATUS IS XXXXXX 
SHOULD BE XXXXXX 


Refer to Appendix C, STATUS- 1 word, for 
definition. The “SHOULD BE..." statement 
is omitted if it is the same as the 
“STATUS IS...” statement. XXXXXX * the 
abbreviated definition. 
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H 1 40 ENTER* (U)NIT, 

<?)ERRS, (H)EAD, 
(OUTPUT , (P) ATT, 
(S)OFT,(C)YL, 
(M)CPU, ( E) XIT 

HI 4 1 CYL = XXXX, HD = 
XX, UNIT = XX 
(PROTECTED) 
(DEFECTIVE) 

( SPARE ) 

H142 PROTECT X/D , 

PUSH RUN 


Enter the contents of the parentheses to 
modify that specific table. 

Example - Type U to modify the unit 
tabl e . 


Designates spare, defective, or protected 
track. This is the result of VP, VD, and 
VS command in an OPDSN program. 


Operator sets the specific PROTECT 
switch. 


HI 43 CLEAR X/D PROTECT, 
PUSH RUN 


Operator clears the specific PROTECT 
switch . 


HI 4 4 NEVER GOT FLAG ON Attempted to output MAKEUP command to 
MAKEUP UNIT = XX unit XX, however, did not receive flag 

indicating its acceptance. Check to make 
sure all other CPU's running are in MCPU 
mode. I f no problems occurred in single 
CPU testing, the problem may be due to 
the device controller. 


HI 45 UNEXPECTED 

INTERRUPT WHEN 
TRYING XXXXXX 
COMMAND 


An interrupt occurred on the controller 
channel when attempting to output one 
of the commands in the command 
sequence for the MC OPDSN command. 


HI 46 CURRENTLY (NOT) Used in telling operator the mode of 

IN MCPU MODE operation of the diagnostic. If no 

problems occurred in single CPU testing, 
the problem may be due to the device 
controll er • 
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J i APPENDIX J 

J BIT 2 DIALOGUE ! + 

: : b : 


Set Switch Register bit 2 to enter the bit 2 dialogue, (The 
diagnostic will complete the current test section before branching to 
the dialogue.) 

Bit 2 dialogue outputs message HI40 ENTER* (U ) N IT, (?) ERRS , ( H) EAD, 
(O)UTPUT, (P)ATT, (S)OFT, (C)YL, (M) CPU, (E)XIT. 

Select the area to be changed or examined by typing the letter in the 
parenthesis . 

In response to the message, H25 WISH TO CHANGE?, type (Y)ES, or (N)Q, 
or (E)XIT, or any of the above letters in parenthesis in the H140 
message to change that specific area. 

Each area of message HI 40 is defined as follows* 

a. (U)NIT is the unit table. The units to be tested by the 
diagnostic are listed in this table. The unit table must be 
totally reconstructed with each change (i.e., to add unit 2 to 
units 0 and I currently in the unit table, type* 0,1,2). 

(Default at initial diagnostic load = unit 0) 

b. (?)ERRS is the unit removal threshold per pass. When the number 
of errors per pass listed in the error table is reached during 
diagnostic execution, the unit being tested is removed from the 
unit table. 

(Default » 40 errors per pass) 

c. (H)EAD is the head table. The heads used in the diagnostic are 
listed in this table. A separate head table exists for each unit 
in the unit table (the unit must be ready at the beginning of the 
current pass). The head table for a given unit must be totally 
reconstructed with each change. 

(Default at initial diagnostic load = heads 0 and 1 for 7905/7906, 

0-4 for 7920, and 0-8 for 
7925) 


d. (OUTPUT allows the operator to determine the heading (H135 S P D 
TSTAT... and E64 STATUS IS... or Just 164 alone) to be used when 
status is output. 

(Default : = messages HI35 and E64 ) 
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It also allows the operator to determine whether or not message 
HI 37 TERMINATION STATUS IS XXXXX SHOULD BE XXXXX is output. 

(Default = H 136 TERMINATION STATUS WILL BE PRINTED) 

e. (P)ATT is the pattern table (the ten patterns used in test section 
2). The patterns are replaced in the order that they are entered. 
Consecutive commas imply no change. 

Example* In response to message H30 T\PE PATTERNS VOU WISH TO 
CHANGE SEPARATED BY COMMAS, type* 1 23232, ,,, 1 77777 


Pattern 

table before change* 


155555 

• 

177777 125252 055555 

• • • 

007417 

• 

Pattern 

table after change* 


123232 

• 

177777 125252 055555 

• • • 

177777 

• 


When the first pattern of the pattern table is used by the 
diagnostic, the pattern is transposed into a 48-bit pattern by 
making the second word of the pattern the same as the first, but 
rotated left one bit (133333). The third word is the same as the 
second, but it is rotated left one bit with the last bit equal to 
zero (066666). This results in each sector having the bit pattern 
110 repeated throughout it. If the first pattern in the pattern 
table is changed, some other 48-bit pattern will be generated. 


(Default pattern table at initial diagnostic load = 

155555 177777 125252 055555 007417 
170360 162745 000000 163346 022222) 

f. (S)OFT allows the operator to determine whether or not soft errors 
are printed. 

(Default at initial diagnostic load = HI 26 SOFT ERRORS WILL BE 
PRINTED) 

g. (C)VL is the cylinder table (contains twelve cylinder numbers). A 
separate cylinder table exists for each drive type. The cylinders 
are replaced in the order that they are entered. (See example in 
step e, (P)ATT.) 

(Default = For 7905/7906: 0, 1, 2 f 4, 8, 16, 32, 64, 128, 192, 

256, and 410. For 7920/7925: 0, 1, 2, 5, 8, 17, 32, 

65, 128, 257, 512, and 822) 

h. (M)CPU tells you whether or not you are in MCPU (multiple CPU 
testing) mode. 
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This test should be used only after each CPU has been checked out 
thoroughly with the rest of the disc subsystem in a single CPU 
environment. Refer to paragraph 3-5 for information concerning 
multiple CPU testing. 

(Default = not in MCPU mode) 

i. (E)XIT resets Switch Register bit 2 and causes the diagnostic to 
branch out of the bit 2 dialogue and begins to execute the 
diagnostic as indicated by the Switch Register options. 
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STATUS, OFFSET, AND ! + 

FILE MASK DEFINITIONS J C \ 


STATUS- I WORD 


15 

14 

13 

12 

1 1 10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

S 

P 

1 ° 

T 

S T 

A 

T 

X 

X 

X 

X 

U 

N 

I 

T 1 


| Not used Unit number of 

★Encoded termination status. current drive. 

— Track is defective if set. 


Track is protected if set. 
Track is spare if set. 


★Encoded termination status 


STATUS- 1 
WORD 
(octal ) 

TSTAT 

(binary) 

DEFINITION 

000000 

00000 

No errors. (NORMAL COMPLET) 

000400 

00001 

Illegal opcode. (ILLEGAL OPCODE) 

001 000 

00010 

Unit available. (UNIT AVAILABLE) 

003400 

00111 

Cylinder compare error. (CVL CMP ERR) 

004000 

01000 

Uncorrectabl e data error. (UNCOR DATA ERR) 

004400 

01001 

Head-sector compare error. (HD/SEC CMP 
ERR) 

005000 

01010 

I/O program error. 

006000 

01100 

End of cylinder. (END OF CVLNDER) 

007000 

01110 

Data overrun. (OVERRUN) 

007400 

01111 

Possibly correctable data error. ( POSS CORR 
DATA) 

0 1 0000 

10000 

Illegal access to spare track. (SPR TRK 
ACCESS) 

010400 

10001 

Defective track. (DEFECTIVE TRK) 

0 1 1 000 

10010 

Access not ready during data operation. 
(ACCSS NR DATOP) 

01 1 400 

1001 1 

Status-2 error. (STATUS-2 ERROR) 

013000 

1011 0 

Attempt to write on protected or defective 
track. ( WRT PROTEC TRK) 

013400 

10111 

Unit unavailable. (UNIT UNAVAIL) 

017400 

11111 

Drive attention. (DRIVE ATTNTION) 
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STATUS- 2 WORD 


15 

14 

13 

12 

1 1 

10 

9 

8 

7 

6 

5 

4 

3 

2 

1 

0 

1 E 

D 

R 

T 

V 

P 

E ■ 

X 

A 

P 

F 

DF 

FS 

SC 

NR 

B 


Drive type:- 


Not used. 


T 


000000 = 7906A ... . . 

000001 = 7920A Attention 

000010 = 7905A 

000011 = 79 25A Protected 


Any error (set if 
bit 4, 2, 1, or 0 
is set) . 


FORMAT switch 
Drive fault — 


L 


Drive busy 
Drive not ready 
Seek check 
First status 


OFFSET WORD 


15 14 13 12 1! 

1 10 

9 

8 

7 

6 

5 4 3 

2 1 0 

Not used. 


n 



j Cylinder 

offset 


Advance clock 
Delay clock — 


Not used 

Sign bit for cylinder offset. 


MASK 


15 14 13 12 II 10 9 8 7 6 5 4 3 2 I 0 


Not used. 

Retry count 





Incremental seek if clear and bit 0 = 1? ^ 


r 


r 


decremental seek if set and bit 0=1. 

Allow track sparing if set. 
Cylinder mode if set? surface mode if clear. 

Allow automatic seek if set. 
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^ START ^ 



^ Set P-register j 
to 10Q> 





S21. Test busy 

S3-6. Test 



bit. 

FORMAT switch 



S23. Test seek 
check. 


V 


I 


Diagnostic 

Configuration 


7 


S7. Test defective 




track status. 



S24-27. Write 

S8. Test protected 



data on disc. 

track status. 





Set P-register 
to 200(V 


S9. Test 

STATUS-2 

error. 




START (SO) 

Test interface 
card and determine 
units connected. 


Test section 
1. 


S1 1 , 12. Format 
and verify all 
selected surfaces 

SI 3-1 5. Test first 
status. 




S29. Perform 
verify in 
cylinder mode. 




i 

^ 


two entries 


Yes 



s. m cylinder table / 

equal 

j No 

S38. Test 
cylinder compare. 


1 

+ 1 

* 

S39. Test head 
sector compare 
with bad sector 
address. 


} 

[ 


-*T«- 


S45. Test 
“Unit unavailable” 
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\. cylinder table 
^V^entry 

|Yes 

S47. Test 
incremental and 
decremental seeks. 


1 


r 

S48. Test read 
with cylinder or 
clock offsets. 
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